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A METHOD AND SYSTEM FOR 
INTEGRATING NETWORK-BASED FUNCTIONALITY 
INTO PC APPLICATIONS AND DOCUMENTS 

BACKGROUND OF THE INVENTION 

The present application claims priority under 35 USC § 119 to Provisional Patent 
Application, serial number 60/217,361, filed on July 11, 2000, for "System and Method for 
Integrating Network-based flinctionality into PC Applications", and is hereby incorporated by 
reference. 

Field of the Invention 

The present invention relates generally to a method and system for providing 
network-based functionality into personal computer applications and documents, and more 
particularly, to a system and method for embedding network-enabling objects into PC documents 
and providing network-based functionahty thereto. 

Description of Related Art 

There exists today a rich class of end user applications generally termed as 
"productivity applications", used to create, view and modify personal computer (PC) documents. 
Readily available PC productivity applications include any PC application for creating a variety 
of documents on a PC, for example, creating spreadsheets for managing and manipulating 
numerical data, creating drawings and illustrations, and for creating mechanical blue prints using 
computer-aided design (CAD) programs. Documents created and managed by such applications 
are typically stored on the same PC (local disk) or a file server on the local network. The content 
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of these documents is generally self-contained; therefore all content presented to the end user is 
stored in the document itself 

On the other hand, there exists a vast quantity of information and variety of 
services that are hosted remotely, accessible via a network. A web browser, for example, is a 
5 convenient vehicle for accessing such content and even for hosting simple applications that are 
downloaded from the network which work with such remote information and services. Such 
simple applications may manifest themselves as more advanced web pages, Java applets, 
browser "plug-ins", or the like. The extended functionahty supported by such simple 
applications often attempts to recreate a segment of functionality found in an existing desktop 
10 apphcation. However, none of these additions to web browsers (or other network clients) 

incorporate the full functionahty of commonly available productivity apphcations. Moreover, as 
additional functionality is deployed to web browsers in attempts to raise their level of 
functionality, bandwidth requirements increase causing the application to become more 
prohibitive to download. 

15 In general, documents managed by productivity applications are self-contained 

and do not allow viewing or manipulation of remote content or access to functionahty provided 
by remote systems and servers on a network. Certain PC applications allow users to embed web 
page links or e-mail address links into a document created by the underlying PC application. 
These PC applications allow users to launch Litemet clients by clicking on the link. However, it 

20 is important to note that the result of performing such an operation from within the PC 

application is for the underlying PC application to separately launch the corresponding Litemet 
client, essentially passing the end user to a distinctly new environment. Since the content being 
viewed in the Internet client, whether a web page or a new email, cannot be manipulated by the 
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original underlying PC application, the user is forced to either work within either the PC 
application or the Internet client; thus, users are limited to one environment or another. 

Common mechanisms for deploying and utilizing network technologies include 

web browsers, media players, e-mail cKents, and/or other Internet chents. Similarly, the content 
presented and manipulated by these various network technologies cannot be integrated fully into 
the PC applications' environment such that the content can then be manipulated by the native 
functionality and tools resident within the PC applications. As a result, while such browsers, 
media players, e-mail clients, and other network technologies allow access to information on the 
Internet or other networks, they do not provide the functions and operations that are typically 
performed by PC appUcations. For example, while a browser allows a user to search the World 
Wide Web, one cannot directly perform ad-hoc analysis of stock data retrieved from the Internet 
using models running within a spreadsheet apphcation. As a result, end users must manually 
move the content into a PC application geared towards such analysis. 

Attempts have also been made to receive and collect remote content from external 
sources from within a PC application for use toward particular specialized tasks. For example, 
certain personal financial management applications retrieve stock data from the Internet and 
bring the data into local views to augment existing content. Unfortunately, once the information 
has been "imported", the local view remains static, instead of updating itself automatically, as 
the remote content changes. Moreover, while the ability to integrate this imported information 
with local content or distributed content from other sources exists in certain limited situations, no 
means are provided by the PC application to extend the access capabilities to include other 
sources of remote content. Users are therefore hmited solely to the types of information/data 
provided by the remote information source. 
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At the same time, other PC apphcations collect and extract data/information from 
multiple sources and bring the data/information into some central location, such as spreadsheets, 
databases and the hke. These PC applications provide the capabihty to extract data/information 
from one or more sources and marshal the data/information into one central location; however 
5 their functionality is primitive. For example, a user may be limited to extracting particular data 
(such as a table of data, but not an individual row or a single paragraph) from a public or static 
web page, or unable to supply required credentials to gain access to a private web site. 
Additionally, the functionality exists solely within the application at hand (a user cannot for 
example apply a query tool for one application to seamlessly retrieve data for another 

10 application). These existing tools are merely provided as limited enhancements to the existing 
application, but fails to provide a platform for development of a wide range of enhanced 
ftinctionality for said application. 

Furthermore, constructing distributed applications that manipulate remote content 
but execute within a network client such as a browser represents an onerous task at best. The 

1 5 remote content cannot be saved locally and manipulated while not connected to the remote 
source and later reused when connected to the original remote location. Additionally, as 
mentioned above, as the level of functionality approaches that of the ftiU desktop productivity 
application, the resulting browser application becomes prohibitively large for typical distribution 
via Litemet download. Lastly, once such a web application has been constructed, it fails to 

20 operate with a mix of both local and remote content. 

Moreover, existing desktop applications may provide a method of extending their 
native capabilities via a scripting interface; however these scripting environments are often 
inferior to typical robust development platforms. When attempting to construct solutions in 
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these environments, developers must resort to more complex code and debugging methods, 
thereby additionally raising development costs and reducing the availability of developers who 
may have the necessary skill sets to implement such solutions. Therefore a need exists for a 
more robust development platform, allowing a developer or end user to quickly build and deploy 
5 applications that expose network functionaUty integrated with PC productivity application 
functionality. 

As such, on one hand, existing PC applications fail to incorporate Litemet and/or 
other general network-based access capabilities as an integral part thereof; on the other hand, 
Internet clients fail to incorporate the full scope of PC apphcation functionality therein. As a 

10 result, these PC applications cannot be utilized for network-based operations and functionahties. 
Furthermore, available PC appUcations fail to provide solid mechanisms for incorporating 
distributed and remote information into their respective documents. For example, while the 
ability to receive network-based information, such as stock quote streams, in real time, directly 
into a spreadsheet or to receive Uve video feeds within a document of today's PC applications, 

15 exists today in certain Umited situations, coupling dynamic remote content with documents that 
are automatically updated when the remote content changes requires functionality currently 
unavailable in such productivity applications. Thus, a user is denied access beyond the 
traditional functions provided by the standard PC application and/or Internet clients, and cannot 
create documents that leverage these network-based features. 

20 In view of these disadvantages, there is a need for a system that allows seamless 

and integrated access to both local as well as distributed content and information. There is a 
further need to extend the network access and utilization capabilities of existing PC applications. 
In addition, there is a need to provide a general as well as extensible framework for extending the 
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network access and utilization capabilities of existing PC applications. Furthermore, there is a 
need for a system to create, manage and utilize documents that contain a mix of immediate as 
well as distributed content. There is further a need for managing PC documents containing PC 
applications so that PC documents can behave as canned applications themselves. There is yet a 

5 further need to enhance the packaging and dehvery of documents containing PC applications so 

that they are suitable for web application deployment. Additionally, there is a need for managing 
access to and use of local content based on remote settings and controls. 



SUMMARY OF THE INVENTION 

10 The present invention overcomes the above-mentioned disadvantages. One aspect 

of the invention provides a general system for augmenting existing PC applications, such as 
word processors, spreadsheets and the hke, with network-based functionahty therein. Users are 
provided with the ability to utilize and leverage the resources of the network/hitemet from within 
PC documents opened in their PC applications. For example, the augmented PC application of 

15 the instant invention allows the user to browse the Internet, read and write emails, send and 

receive instant messages, perform page scraping, receive stock quotes in real time, access remote 
databases over the Internet, or perform other similar network-based functions from within PC 
documents, and be able to use their PC apphcation functionality against both local and remote 
content in concert. 

20 In one embodiment of the present invention, a personal computer document with 

network-based functionality is disclosed. The personal computer document is used with the 
personal computer application augmented with a network-functionality software that is resident 
in computer memory. The personal computer document is coupled with network-enabling 
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objects that are configured to provide network-based functionality to the personal computer 
document. 

The invention described herein supports integration of a wide range of network- 
based user interfaces, content, data, and functionality into personal computer applications and 
5 personal computer documents. The networks that can be used in conjunction with this 
technology include the Internet as well as other networks. 

The invention described herein enables the development, deployment, and use of 
these network-based services and documents with network-based functionality. The invention, 
allows integration of a wide range of network-based, including hitemet-based, user interfaces, 
10 content, data, and functionahty into the augmented PC apphcations and also into PC documents 
used or produced by such augmented PC applications. Thus, the invention enables professional 
developers as well as end users to develop PC application-based, network-enabled documents 
and applications by using augmented versions of PC apphcations with which they are already 
famihar. This simplifies and improves the development of network-based apphcations or 
15 documents. 

The present invention also provides a client/server architecture wherein one or 
more users may connect to a network, comprising one or more independent servers, for receiving 
network-based functionality within their personal computer applications and personal computer 
documents. 

20 The present invention may include an architecture that involves four software 

components. The first component is a document-independent, run-time client-side code, through 
which a personal computer application is extended by network-enabling software that facilitates 
access to network-enhanced services and functionalities from within the application 
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environment. The second component of the architecture is the enhanced personal computer 
document, which includes network-enabling objects. The third component of the architecture is 
a design tool for creating the enhanced personal computer document. The fourth component of 
the architecture is server-side code that manages interactions between chents and Intemet 
resources and interactions among multiple end users. 

These aspects and other objects, features^ and advantages of the present invention 
are described in the following Detailed Description which is to be read in conjunction with the 
accompanying drawings. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. lA is a block diagram of a personal computer document in a personal 
computer application augmented by a PCA extender; 

FIG. IB is a block diagram of another embodiment of a personal computer 
5 document in a personal computer application augmented by a PCA extender; 

FIG. IC is a schematic diagram of a network-enabhng object in accordance with 
the present invention; 

FIG. 2 is a schematic diagram of a personal computer application extended by a 
client extender in accordance with one embodiment of the present invention; 
10 FIG. 3 A is a schematic diagram of one embodiment of network-enabling software 

for use by software developers; 

FIG. 3B is a schematic diagram of one embodiment of network-enabling software 
for use by lay users; 

FIG. 4 is a schematic flow diagram depicting the process for providing network- 
1 5 enabling software to a personal computer application; 

FIG. 5 is a block diagram of a personal computer application that provides users 
with built-in tools for creating documents with network-based fimctionality; 

FIG. 6 is a schematic diagram of a personal computer document in accordance 
with the present invention; 
20 FIGS. 7A-7D are schematic diagrams of different states of communication 

between the network-enabling objects in the PC document with one or more controls installed on 
the PC; 
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FIG. 8 is a schematic flow diagram depicting the process for creating a personal 
computer document with network-enabhng objects embedded therein; 

Fig. 9 is a schematic flow diagram depicting the process for launching network- 
based functionality with a personal computer document; 
5 FIG. 10 is a schematic block diagram depicting the client/server system of one 

emxbodiment of the present invention for providing network-based functionality with a personal 
computer document; 

FIG. 1 1 A-1 IB are screen-shots depicting two embodiments of a personal 
computer document in accordance with the present invention; 
10 FIGS. 12A-12E are screen-shots of a personal computer document augmented 

with developer tools in accordance with the present invention; 

FIG. 13 is a schematic block diagram depicting the cHent/server system of an 
embodiment of the present invention for developing and accessing a web page as an embedded 
object that is produced using a spreadsheet. 
15 FIG. 14 is a schematic flow diagram depicting the process for developing and 

accessing a web page as an embedded object that is produced using a spreadsheet application; 

FIG. 15 is a schematic flow diagram depicting the process of the operation by a 
user to use a web page created in accordance with the process of Fig. 14; 

FIG. 16 is a schematic block diagram depicting the client/server system of an 

20 embodiment of the present invention that facilitates the cooperative writing and editing of 
newspaper articles and other written works; 

FIG. 17 is a schematic flow diagram depicting the process of using the system of 
FIG. 1 6 by a software developer; 

10 
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FIG. 18 is a schematic flow diagram depicting the process of using the system of 
FIG. 16by a^Aoiter; 

FIG. 19 is a schematic flow diagram depicting the process of using the system of 

FIG. 16 by an editor; 

5 FIG. 20 is a schematic block diagram depicting the client/server system of an 

embodiment of the present invention that allows an illustrator or another author to create, 
distribute, and Hcense illustrations and other works of authorship; 

FIG. 21is a schematic flow diagram depicting the process of using the system of 
FIG. 20 by an illustrator; and 
10 FIG. 22 is a schematic flow diagram depicting the process of using the system of 

FIG. 20 by a customer. 

With reference to the following detailed description, the aforementioned drawings 
will be described in greater detail below. The leading reference nimieral in each drawing 
indicates the first drawing in which the reference numeral is introduced (e.g., elements 320 and 
15 1 140 are introduced in figures 3 and 1 1 respectively). 
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DETAILED DESCRIPTION 

The present invention relates to a system and method for providing network-based 
fimctionahty to a PC document. Initially, a PC application (PCA), which is a software program 
used by a PC for a particular desired task, is augmented with network-enabling software that 
5 allows users to provide new features to the PCA. The network-enabling software of the present 
invention enables users to generate, modify and utihze PC documents with embedded objects. 
The objects can work in conjunction with the network-enabhng software to launch and utilize 
network-based functionality from within PC documents. The present invention enables the use 
of a wide array of public and private network-based content and services including, but not 

10 hmited to, content and web services and other Internet-based content and services, within a PCA, 
such that these services can be viewed and used within such applications, and within the 
documents associated with these applications. 

It should be noted that the present invention, even when described in connection 
with the Internet specifically, may be applied equally to local area networks (LANs), private 

1 5 "Intranets," hybrid public-private "Extranets," virtual private networks (VPN), and other 
networks. 

The services that can be provided and used within a PCA include web browsing, 
electronic mail (e-mail), instant messaging, digital rights management (DRM), remote database 
access over the Internet, and other Internet-based services, as well as combinations of these 
20 content and services. These services may be provided from within a word processor such as 
Microsoft WORD, a spreadsheet such as Microsoft EXCEL, a design program such as 
AUTOCAD, a desktop publishing program such as QUARK EXPRESS, or any other PCA. 

12 
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According to the invention, once the network-enabhng software has been installed 
on a personal computer, the network-enabling software may automatically load when the 
augmented PCA is loaded. Users of the augmented PCA may load existing PC documents or 
create new ones with the augmented PCA. Once a PC document is open within the augmented 

5 PCA, the user is able to make any of the standard operations thereto, such as creating, adding or 
modifying content therein. Furthermore, the augmented PCA allows the user to embed network- 
enabling objects in the PC document by a plurality of mechanisms. 

According to the invention, the network-enabling objects embedded in a PC 
document allow users to launch network-based operations from within the PC document when 

10 the associated PCA has the network-functionality software running alongside. Such network- 
enabling objects may allow users to perform web browsing, electronic mail (e-mail), instant 
messaging, remote database access over the Internet, DRM, and/or a plurality of other network- 
based operations consistent with the purpose of the present invention from within PC documents. 
The invention also enables integration of PCAs as well as PC documents with remote 

15 applications, databases, and data sources, where communication between them may occur over a 
plurality of network types. 

According to the invention, both fixed and customizable objects may be placed 
within individual PC documents to provide network-based functionality thereto. The network- 
enabhng objects can either be visible to the user within the document or hidden. The network- 

20 enabhng objects may contain data, UI elements, and code such as Visual Basic scripts. 

According to the invention, the network-enabling objects can present the user with specific 
options, and act in response to user-provided information and choices, and/or they may take 
network-related actions automatically, driven solely by software commands. 

13 
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As noted above, the actions taken by the network-enabhng objects placed within 
PC documents can include any combination or sequence of a wide array of Internet-related 
actions, including but not limited to checking or sending e-mail, checking or sending Internet- 
based voicemail, querying remote databases over the Internet, requesting or updating a web page, 
5 invoking a remote application over the Internet, establishing a real-time data feed with a specific 
Internet data source, DRM, or sending a real-time message. 

It should be noted that the ability to make use of these services and functionahties 
is not restricted to existing PCAs and PC dociunents. Such services and functionalities can also 
be provided through future PCAs not yet developed, future PC documents not yet developed, and 
10 through augmented or enhanced future versions of existing applications and document types, or 
through wireless devices. 

According to another embodiment, the PC document may be provided with an 
installation facility to install the network-enabling software on a PC where the PC document 
resides but where the underlying PCA has not been provided with the network-enabling software 
15 of the present invention. The invention discloses a system for automatic installation of the 
network-enabling software so that new PC documents with network-enabling objects may be 

created, manipulated, enhanced and supported. 

The invention further discloses the packaging of network-based functionalities via 
software development kits (SDKs) and application programming interfaces (APIs) usable by 
20 professional PCA developers. It will be appreciated that the functionahties provided by the 

invention, the architecture in which they are embedded, and the APIs through which they can be 
utilized, greatly simplify and improve the development of new, network-enabled PCAs and PC 
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documents. These functionalities can also be provided for network-specific documents such as 
e-mail messages that are processed by SMTP/POP e-mail clients. 

In general, the present invention may include an architecture that involves four 
software components. The first component is a document-independent, run-time client-side 
5 code, through which a personal computer apphcation is extended by network-enabling software 
that facilitates access to network-enhanced services and functionalities from within the 
application environment. The second component of the architecture is the enhanced personal 
computer document, which includes network-enabling objects. The third component of the 
architecture is a design tool for creating the enhanced personal computer document. The fourth 

10 component of the architecture is server-side code that manages interactions between chents and 
hitemet resources and interactions among multiple end-users. 

The runtime client-side code may be configured as one or more distinct sub- 
components. For example, one sub-component may constitute generic client-side code that 
handles aspects of system operation common to all appUcations, while a second sub-component 

15 may be application specific (e.g., the portion of the code that controls the appUcation's unique 
user interface). This runtime support code at the client can be developed using any of a number 
of programming languages, such as C, Java and Visual Basic. One of the fimctions of the 
runtime client-side code is to wrap and package low-level transport protocols such as TCP/IP and 
HTTP into elements that can be manipulated and that provide specific, high-level fimctional 

20 capabilities, such as wrapping SMTP to provide easy-to-use email capabilities, wrapping HTTP 
Web page access and parsing to allow easy access to hve infonnation on web pages. The 
wrapping is done in a layered fashion so that end-users can create and/or manipulate the 

15 
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element-s without having any programming capabilities whatsoever, yet developers can leverage 
scripting or lower-level programming to access more advanced facilities. 

The second functionality of this runtime client-side code is to mtegrate With the 
hosting PCA. This integration falls generally into three categories. The first category simply 
5 provides a seamless runtime environment so that these services run and are available from within 
the application process. This makes the packaged services available for calling from within 
scripts in enhanced documents and from application code itself, and is generally enabled by 
running at least part of the support code as an add-in to the application itself The second 
category of integration is at the user interface (UI) level, where the enhanced functionality 

10 elements are exposed as operations on toolbars and menus, and as objects in enhanced 
documents themselves. This integration is enabled through a combination of standard 
windowing facilities on the client platform, and use of the apphcation and document object 
models to allow integrated rendering of the UI elements and handling of associated events. This, 
for example, enables an end-user to drag an email button that has been provided on a toolbar into 

15 a document, such that the button is rendered as part of the document and that when the button is 
pressed a pre-defined message is emailed to the author of the docimient or other specified 
recipient. The end-user would need no programming ability to perform this embedding and 
configuration, having only to fill in the content of the message and the name or email address of 
the recipient. The third integration category relates to embedded applications, and involves 

20 controlling the behavior of the hosting apphcation itself when an embedded application has been 
placed in "run mode". Document-based applications are generally not designed to behave as 
application containers for embedded applications, and when used in this manner must be 
managed carefully to prevent unwarranted operations by end-users. This management or control 
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can involve blocking certain operations, prevention of the embedded application from being 
rearranged or reconfigured, or modifying and/or augmenting various ordinary tasks such as 
saving a local copy of the embedded application enhanced document. This control is achieved 
again by packaging some or all of the runtime support code as an extension (such as an add-in or 
5 a plug-in) so that it runs in close cooperation with the hosting PCA, and in working with the 
PCA extension to change the PCA behavior. The PCA extension can change the PCA behavior 
by a combination of handling the entry points and events, overriding handling by the PCA itself, 
and extending the PCA object model through new, custom code. 

hi this runtime environment, an augmented PCA may allow an end-user to 

10 download and open PC documents within the PCA's native environment. In one embodiment, 
the document may constitute a web page, or a PCA version thereof, downloaded from a web 
server. The augmented desktop application and enhanced document together form an hitemet or 
network-enabled application that facilitates access to remote services and functionalities while 
retaining functionality inherently provided by the desktop application. Access to distributed 

1 5 services may be via any network or protocol. 

The enhanced PC document includes Internet-enabling objects which can be 
document specific and placed into a document such as a PCA-based web page and the like by 
either a developer or end-user. The UI of such objects can include buttons, lists, menus, and 
forms. Their functionality can include combinations of Internet or network-based functions such 

20 as sending and receiving data, sending and receiving e-mail messages, causing documents to be 
posted to web sites, and other functions enabled by the technology. The functionality of such 
objects is specified by custom-developed software, which can be associated with the object's UI, 
and then activated by software events and/or user-issued commands. Once written, these objects 
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can be separately transmitted via the Internet and stored on client machines for use by developers 
and end-users. 

In certain embodiments of the present invention, enhanced PC documents created 
by a developer can be defined as embedded applications, consisting of three defined elements, 

5 namely a wireframe, population data and form data. 

The wireframe includes static content and scripting code that is generally not 
modified during runtime within a PCA residing on an end-user's system. The static content also 
includes the layout configuration of the document viewed by the end-user, such as fonts and/or 
colors. The script code allows end-users or developers to extend the built-in functionahty of the 

10 PCA or simply create macros containing often-used packaged sequences of operations (for 

example, repeatedly creating the same customized chart from a set of data). In the context of the 
wirefi-ame, the script code may contain code to assist in supporting the present invention. 

The population data is dynamically generated data used to populate specified 
areas within a wireframe during a desktop appHcation's runtime. Typically, such data is supphed 

15 by a server and is designated "read only", but where appropriate the data may be editable, or can 
be pushed back to the server for other custom processing. Population data may be used in a 
variety of ways, including to populate fields, strings, and pick hsts for display to the user, or 
transparently as calculation data operated on by the application. It may also be defined to be a 
function of information maintained in the associated wireframe, user input, or both. It may 

20 typically be generated or retrieved upon actions such as startup, connection, or form submission, 
or a manual refresh request or in real-time in response to remote data changes. 

The form data is data which is specified or manipulated at the client by end-users 
during runtime. Form data is usually one-way data transmitted from chent to server. But in 
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some circumstances it may be desirable to read such data from a server (for example, as cached 
prior information to pre-populate a user form or as smart defaults for a user form) to pre-fiU 
forms within a wireframe. Form data includes data items, such as data entered into text box 
prompts (for example, asking for a user's usemame and password for authentication) and 
5 parameterized data entered into defined queries (such as stock ticker symbol as a parameter in a 
we b query). 

The design tool for creating enhanced PCDs augments a PCA so that a software 
developer is provided with fimctionality that is similar to a special-purpose PCA that is oriented 
towards the design of complex enhanced PC documents, services and apphcations. hi the 

10 design-time environment, an augmented PCA can provide a developer with tools for creating the 
distributed documents described above. 

It should be noted that support for the design-time environment is similar to the 
packaging and functionality described above for the general runtime support except that the 
integration with and control of the containing apphcation is generally more extensive. In 

15 addition, the elements and tools that are exposed to a developer are generally more detailed and 
in many cases will involve scripting or code to achieve the greatest level of functionality and 
control. The principal difference in functionality in the developer's design time tools and 
environment from an end-user's authoring environment is that the former provides extensive 
controls targeted at defining and managing the behavior of the containing application, while the 

20 latter is focused on creating and managing elements in enhanced documents and/or directly 
accessing the distributed functionality and services of the runtime itself. The design-time 
support code will generally be packaged as one or more separate add-ins and/or tools from the 
standard runtime code. Furthermore, the runtime code can be divided along functional 
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boundaries into multiple, separately-distributed pieces as well. For example, this runtime could 
be sub-divided into components or libraries that are completely independent of any particular 
enabled application (perhaps as a collection of COM objects), an apphcation-specific add-in that 
provides base end-user tools and support for enhanced documents, and a second application- 

5 specific add-in that provides for application and environment control for embedded apphcations, 
where the enhanced document is actually intended to be an embedded apphcation and have a 
distinct design mode and run mode. The development environment may then be packaged as one 
or more additional add-ins distinct from the above. 

The design tool allows the developer to design the distributed PC documents 

10 described above. The developer may be provided with tools that allow him or her to embed 
internet or network-related functionality (e.g., automated e-mail notifications) in the PC 
document, control the UI that will be presented to the end-user when the document is opened, 
define population-data sources and how the data is displayed, define business rules, and various 
other functions within the scope of the present invention. 

15 The developer may also create parallel browser-based views of these distributed 

documents- The choice of whether to download a browser-based view or desktop-application- 
based view of a page may be controlled by preferences set by the end-user and stored at a server. 
The developer may also wish to augment the browser-based version of the page so that it 
provides some of the additional functionality included in the PC A based version. Examples of 

20 such network- functionality may include scripting for form-data posting, HTML-based 

lightweight grid handling, and inserting meta-tags into the browser-based view of a page for 
managing later wireframe synchronization with the desktop application version. 
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Since some developers may wish to augment the browser-based version of the 
web apphcation still further, the invention provides the abihty to retain such modifications and 
enhancements through subsequent desktop apphcation-to-augmented-HTML exports, and push 
modifications back to the desktop apphcation version where appropriate. A typical example of 

5 HTML-side augmentation is inserting client-side scripting to add functionality to the UI beyond 
that provided by a browser (for example, ornate hover buttons). Additional desktop apphcation- 
side augmentation might involve a business analyst defining macros and calculations linking 
various data items within the application. 

The invention provides for server-side components that manage interactions 

10 between chents and Internet resources and/or interactions among multiple end-users, the latter 
greatly facilitating client peer-to-peer operations. Specific services can be characterized by the 
kind of server support they require. For example, E-mail notifications require basic SMTP mail 
services. Semi-standardized services can be leveraged for functionality such as remote database 
access, messaging, conferencing and the hke. Custom remote services can be leveraged for 

1 5 accessing proprietary information feeds (such as real-time stock quotes), document archives and 
repositories, corporate workflow systems and the like. For these latter categories, the present 
invention adds value by providing a generalized framework for finding and accessing the remote 
services, and for opening standardized connections for communication and data transfer to the 
client PCA. 

20 With reference to the figures, various embodiments of the present invention will 

now be described in greater detail. FIG, 1 A provides an illustration of a system in accordance 
with the present invention. A PCA 100 is provided with a PC document 110. In accordance 
with the present invention, the PCA 100 is not Umited to any particular task, form or vendor. 
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According to the present invention, the PC is not limited to any particular type, and is operable 
on any machine with a suitable operating system having GUI facilities. The operating system for 
use in the present invention is also not limited to any particular type, and may include 
Microsoft® Windows®, Macintosh, UNIX, Linux, Net BSD, FreeBSD, and the like. These 
5 functionalities can also be provided to applications running on Personal Digital Assistant (PDA) 
devices, cellular phones and other "light clients" connected to the Internet via wireless 
communications. 

According to the invention, the PC A 100 is augmented so that it is capable of 
developing, using, accessing, manipulating, and displaying network-enhanced documents. Such 

10 an augmented PC A 100, which allows for the creation and use of network-enhanced documents, 
essentially be termed as an apphcation within an application. The present invention enables 
access to Internet-based services, data, and functionalities within network-enhanced documents, 
which are developed, edited, and viewed via the augmented PC A 100. The invention provides 
for tools, pre-defined scripts, and supporting runtime code that make construction of such 

15 enhanced documents in the desktop application's native format simple enough for end-users, yet 
flexible and comprehensive enough for developers to rapidly construct complex, powerful 

applications that leverage both Internet/network services and the client-side fimctionahty of the 

particular desktop application. Where possible, the technology leverages a built-in script 
execution capability provided by the PCA 100, such as Visual Basic for AppUcations facilities 
20 provided by Microsoft. Thus, this system provides a powerful environment for developing and 
using enhanced documents with rich and familiar client-side functionality. 

The PC document 110 is an object that is typicahy created, used, manipulated, 
augmented and saved by the underlying PCA 100. For example, a spreadsheet is the document 
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where the underlying PC A 100 may be a spreadsheet application, such as Microsoft® Excel or 
Corel{S) Quattro®. The PC document 110 may be provided with embedded or associated code 
that provides access to distributed, usually Intemet-based, services, data and functionalities 
residing on multiple computer systems connected via the Internet or other network. These 
5 services and functionalities may be made available via the Internet using the typical network 
protocols, such as hypertext transfer protocol (HTTP), FTP, SMTP (e-mail), streaming media, or 
RMI. 

PC A 100 is provided with a PCA extender 120. The PC A extender 120 enables 
users to augment the PCA 100 with network-based functionality. The PC document 1 10 is 

10 provided with network-enabling objects 130 that provide network-based functionality lo the PC 
document 110. The network-enabling objects 130 may be used to provide any network-based 
functionality fi-om within the PC document 1 10. For example, the network-enabhng objects 130 
may be used for browsing the Internet, screen scraping, sending and receiving electronic mail (e- 
mail), instant messaging, chat, internet telephony, streaming media, stock quote retrieval, web 

15 page update detection, workflow, conferencing, licensing, automatic notification of a certain 
event, usage monitoring, rephcation and synchronization and other similar network-based tasks 
and content. 

The network-enabling object 130, which is placed inside the PC document 110, 
can perform a wide range of network-based functions, as specified by a developer. Such 
20 network-enabling objects 130 can include UI elements, such as buttons, pick lists, and menus, 
program code, such as Visual Basic scripts that perform functions, and data elements. These 
objects can be placed into the PC document 1 10 by developers and end-users, where they remain 
as part of the PC document 110 structure, upon saving the PC document 110. 
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Coupling the PCA extender 120 to the embedded network-enabhng object 130 
provides one or multiple network-based capabilities, such as web browsing and e-mail within the 
PCA 100. As a result, the PCA 100 serves as the UI to the Internet and other networks, which 
eliminates the need to rely on separate Internet-specific client applications, such as web browsers 
5 (e.g., Netscape Navigator), e-mail clients (e.g., Microsoft Outlook or Eudora), and media players 
(e.g., distributed by Real Networks). Furthermore, the provision of web access within the PCA 

100, employing the native data types and facilities of the PCA 100 for the representation of web 

pages, allows users to use the web site from within the PCA 100. This allows users to have 
access to functions such as browsing pages, navigating through hyperlinks or image maps, 

1 0 entering data in forms, and a variety of other network-based functions. 

According to one embodiment of the invention, the PCA extender 120 may 
interact with one or more Component Object Model (COM) components on a local PC to support 
and provide additional functionahty within the PCA as well as PC document, as shown in FIG. 
IB. COM is a software architecture that allows components made by different software vendors 

.15 to be combined into a variety of applications. COM defines a standard for component 

interoperability and provides the underlying support for Object Linking and Embedding (OLE) 
items and ActiveX® controls to communicate with other OLE objects or ActiveX® controls. 
OLE is a framework for a compound document technology, available from Microsoft®. OLE is 
a set of APIs to create and display a compound document. An ActiveX® control is a software 

20 module based on the COM architecture, which enables a program to add fimctionahty by calling 
ready-made components that blend in and appear as normal parts of the PCA. ActiveX® 
controls are typically used to add user interface functions, such as 3-D toolbars, a notepad, 
calculator oi even a spreadsheet. In many cases, COM provides the underlying services of 
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interface negotiation, life cycle management (determining when an object can be removed from a 
system), software licensing, and event services (putting one object into service as the result of an 
event that has happened to another object). 

According to the present invention, the network-enabling objects 130 
5 communicate with the PC A extender 120 to enable the document to receive network-based 

functionality therein. The PCA extender 120 communicates with the COM component(s) 140 to 
allow the embedded network-enabling objects 130 in the PC document 1 10 to provide additional 
functionahty to the PC document. 

FIG. IC provides an illustration of one embodiment of the network-enabhng 

10 object 130 in accordance with the present invention. The network-enabling object 130 is used to 
launch the network-based functionality within the PC document 110. The network-enabling 
object 130 is embedded in the PC document 1 10 so that the functionahty of the network-enabhng 
object 130 becomes at integral part of the PC document 110. The network-enabling object 130 
comprises two main components, initiahzation code 190 for initializing and launching the 

15 network-based functionality prior to runtime, and runtime code 192 for providing the network- 
based functionality during runtime. As a result, the initialization code 190 causes the launching 
of the network-based functionality, while the runtime code 192 enables a user to continuously 
receive network-based functionality within the PC document 110. 

It should be noted that the initialization code 190 plays no role during runtime, 

20 and remains static/dormant during runtime of the network-based functionahty. According to one 
embodiment, the runtime code 192 can be provided with all the necessary functions or routines 
for enabling the PCA extender 120 to read the necessary information and then initialize and 
launch the network-based functionality. According to another embodiment, the PC document 
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110 can be embedded with code that includes some of the necessary functions/routines to 
initialize and launch the network-based functionality, and the initiahzation code 190 can be 
provided with the bare minimum routines to merely initialize the network-enabhng object 130. 

According to one embodiment, the network-enabling object 130 may be provided 
5 with a Ul 194 that makes the network-enabling object 130 visible to the user. It should be noted 
that providing the UI 194 for the network-enabhng object 130 is strictly optional, since a number 
of network-enabling objects 130 may be provided such that they are hidden from the user's view 
while still providing network-based functionality. 

FIG. 2 provides an illustration of a PCA 100 in association with the network- 

10 enabling software 210 of the present invention and other generic add-in(s) 220 that may be 

supphed by oae or more third-party vendors or developers. As noted above, the PCA 1 00 is not 
limited to any particular task, form or vendor. Accordingly, the PCA 100 may be a spreadsheet 
application, a word processing appUcation, a desktop publishing apphcation, a presentation 
graphics tool, multimedia development tools (for music, video and the like), a computer aided 

15 design tool, a project management application, a cUent database manager, a personal finance 
organizer, a personal information management tool, a browser, an e-mail client, an instant 
messaging client, a chat cHent and other software. Furthermore, the PCA 100 may be provided 
by any vendor, including Microsoft®, Corel®, Sun Microsystems and the hke. 

The PCA 100 comprises native PCA code 230. The native PCA code 230 

20 includes code that makes the PCA 100 operational and provides the functionality and features 
that are standard for the PCA 100. The native PCA code 230 generally comprises the code that 
creates and provides the user interface (UI) 232 for the underlying PCA 100, 
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The native PC A code 230 exposes a native object model 235. The native object 
model 235 provides a description of an object architecture, including the details of the object 
structure, interfaces between objects and other object-oriented features and functions. The native 
object model 235 enables the use of add-ins 220 and network-enabling software 210 so that the 
5 functionality of the add-ins 220 and network-enabling software 210 can seamlessly be integrated 
with the original functionahty and features of the PC A 100. 

The native PCA code 230 may also include an Application Program Interface 
(API) 240, which may be a part of the native object model 235. The API 240 provides a 
language and message format used by the PCA 100 to communicate with the operating system or 

10 some other system or control program or communications protocol. The API 240 is 

implemented by custom authored components, which leverage the API 240 and manipulate the 
PCA 1 00. The API 240 also provides a method for extending the PCA 100 by the PCA extender 
130 or other COM objects, allowing software developers to author custom functionahty; as a 
result, the API 240 allows manipulation of the operation of the PCA 100 from an extemal source, 

15 as opposed to from within the PCA 100 and/or the PC document 110. The API 240 provides 
developers a blueprint of how to manipulate the PCA 100 by publishing a consistent set of 
interfaces. 

The native PCA code 230 provides a native script engine 250. The native script 
engine 250 is a facility in the PCA 100 that can execute interpreted languages, such as Visual 
20 Basic, JScript scripts and/or other types of scripts. The native script engine 250 allows the script 
code in the PC document 1 10 to execute and manipulate the PCA 100 environment. 

The native PCA code 230 may include a PCA extension enabler 260 which allows 
and facilitates the use of add-ins and/or plug-ins with the PCA 100. The PCA extension enabler 
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260 enables add-ins and/or plug-ins that have been added to the PCA 100 to be loaded and run 
automatically when the PCA 100 is launched. Generally, the PCA extension enabler 260 is a 
manifestation of the API 240. As such, the PCA 100 may either have an API 240 or a PCA 
extension enabler 260. 

5 Using the available features of the PCA 100, one can create a new document 110 

or open an existing document 1 10 to perform operations thereon. The network-enabling 
software 210 allows users to embed network-enabling objects into the document 110, which will 
be described in greater detail below. Once the network-enabling objects are embedded in the 
document 110, the network-enabling software 210 allows a user to use the network-enabling 

10 objects and receive the network-based functionality in their docutnents 1 10, as well as use the 
standard functions and features provided by the PCA 100. 

FIG. 3 A provides an illustration of one embodiment of the network-enabling 
software 210. The network-enabling software 210 includes the PCA extender 120, which 
provides any standard PCA 100 with a one or more network-based capabilities. 

15 The PCA extender 120, which provides runtime support, includes network- 

functionality services 310 as well as application services 315. The network-functionality 
services 310 may include session management, security and location management that provide 
network-based functionality, as well as some combination of the individual network- 
functionality services. The network-functionality services 310 provide runtime support for the 

20 network-based functionality. The network-functionality services 310 expose an API with 

methods than can be called by the network-enabling objects 130 and scripts from within the PC 
document 1 10 to use one or a plurality of network-based functionalities. The network- 
functionality services 310 also includes the base functionahty for packing away script code of the 
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PC document 1 10 for safe and easy network transport as well as unpacking a script code 720 
(FIG. 6) of the PC document 110 when the PC document 1 10 is opened. 

The application services 315 may include XML parsing and other handling, event 
handling and service management, query routing, document packaging, caching, data 
5 initiahzation and persistence, conmiand routing and other similar services, as well as some 

combination of the individual application services. The application services 315 provide runtime 
support for the embedded applications and/or network-enabUng objects 130 in the PC document 

no. 

According to another embodiment, the PC A extender 120 is a COM component. 

10 The PC A extender 120 is deployed as a dynamic link library (DLL) file, which is not launched 
directly by the user but may be called by the PCA 100 for receiving network-based functionahty. 
As such, the PCA extender 120 may also be used by any application running system- wide, in 
addition to being accessible within the PCA 100. It should be noted that designing the PCA 
extender 120 as a DLL file is just one method of deployment, and various other manners of 

15 deployment exist within the scope of the present invention. As such, each functionality of the 
PCA extender 120 may be provided as a separate routine, class or function in the DLL file, 
which may be packaged to include one or more of the network-based functionalities hsted above. 

It should be noted that the PCA extender 120 may be provided with just the 
network-functionality services 310 or just the application services 315 or a combination of the 

20 two. Furthermore, the scope of the present invention is not limited by the types of services 
included in the network- functionality services 310 and/or the apphcation services 315. 

The network-enabUng software 210 may further be provided with developer tools 
320, which provide a plurality of functionalities to a developer who wishes to create an enhanced 
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PC document 110. The developer tools 320 may automatically be invoked upon the launching of 
the PC A 100, According to one embodiment, the developer tools 320 have a UI for display to 
the developer in the form of a toolbar. The developer tools 320 also allow manipulation of an 
information model 790 (FIG. 7D) for the PC A 100, including handling of wireframe data, 
5 population data, and the queries used to retrieve the population data. The developer tools 320 
provide software developers with the ability to construct network-enabled PCAs and create end- 
user tools and utilities, and network-enabling objects 130. The developed functionality may be 
used for various network-based capabilities. It should be noted that the functionality is 
developed in accordance with the information model 790 (FIG. 7D). 

10 The developer tools 320 are configured to provide various sets of functionality, 

enabhng a developer to build and deploy a compatible network-based PC document. The 
functionality may include layout utihties, forms management, query management, data modeler, 
a packaging assistant, and other miscellaneous utilities and operations that assist in network- 
based activities, along with any combination of one or more of the enumerated functions. 

15 According to one embodiment, the developer tools 320 are created and packaged 

as a COM component. The developer tools 320 package is deployed as a DLL file. As such, the 
developer tools 320 may also be used by any application running system-wide, in addition to 
being accessible within the underlying PC A 100. According to another embodiment, each 
functionality of the developer tools 320 may be provided as a distinct COM component that can 

20 be installed by the software developers at their own wish. According to yet another embodiment, 
groups of functionalities of the developer tools 320 may combined into single COM components 
that can be installed by software developers at their own wish. It should be noted that designing 
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the developer tools 320 as a DLL file is just one method of deployment, and various other 
manners of deployment exist within the scope of the present invention. 

The PCA extender 120 and the developer tools 320 are integrated or coupled to 
the PCA 100 through the PCA extension enabler 260. This integration may be achieved through 
5 standard methods of extensibility. It should be noted that the PCA 100 may make itself 
extensible through a variety of means. For example, Microsoft's products can be extended 
through what they term as an "add-in" model, where the COM object extenders, such as the 
developer tools 320 and the PCA extender 120, are defined as add-ins at design time, through, 
for example, the use of a wizard or by implementing a required programming interface. 
10 FIG. 3B provides an illustration of a second embodiment of the network-enabling 

software 210 for use by end-users. The network-enabling software 210 is provided with the PCA 
extender 120 that provides the PCA 100 with a plurality of network-based capabihties, as well as 
a plurality of user tools 330. 

As noted above, the PCA extender 120, which provides runtime support, includes 

15 network-fimctionality services 310 as well as application services 315. It should be noted that 
the PCA extender 120 may be provided with just the network- functionality services 310 or just 
the application services 315 or a combination of the two. Furthermore, the scope of the present 
invention is not limited by the types of services included in the network- functionality services 
310 and/or the application services 315. 

20 The network-enabling software 210 may further be provided with a pluraUty of 

user tools 330. The user tools 330 provide the ability for a user to receive network-based 
functionality within the desired PCA 100. The user tools 330 enable end-users to embed 
network-enabling objects 130 and functionality into their PC documents 110 through the use of 
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toolbars, user wizards and the like. In other words, the user tools 330 may comprise a UI that 
blends in with the UI 232 of the PC A 100, wherein the users can utilize the UI of the user tools 
330 to seamlessly embed the desired objects 130 for the network-based functionality in the PC 
document 110. 

5 According to one embodiment of the invention, the user tools 330 are configured 

to provide various optional features, such as page scraping, stock quotes in real time, and other 
miscellaneous utilities and operations that assist in network-based activities within the spirit of 
the present invention. As a result, the user tools 330 enable users to embed live stock feeds, 
create objects to send and receive e-mails, selected web pages to embed in the PC document 1 10, 

10 and other similar network-based functions. The user tools 330 allow embedding of network- 
enabling objects 130 that use the network-functionality services 310 at runtime to achieve the 
network-based functionality. 

As noted above, the user tools 330 often work in conjunction with the PC A 
extender 120 to provide said network-based functionality. 

15 It should be noted that the user tools 330 are intended for the end user. On the 

other hand, the developer tools 320 are intended for the developer. The PC A extender 120 may 
be utiUzed by both the user tools 330 as well as the developer tools 320. As such, if for example 
one created a set of functionality geared at lawyers, called "lawyer tools," the lawyer tools may 
leverage some of the packaged functions of the PC A extender 120 in addition to the functionality 

20 contained therein. It should be noted that all components of the network-functionality software 
210 work in conjunction with the network-enabling objects 130 in the PC document 1 10. 

According to one embodiment, the user tools 330 are created and packaged as a 
COM component. The user tools 330 are deployed as one DLL file. According to another 
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embodiment, the user tools 330 may be provided as distinct COM components that can be 
installed by software developers at their own wish. It should be noted that designing the user 
tools 330 as a DLL file is just one method of deployment, and various other manners of 
deployment exist within the scope of the present invention. 
5 The present invention also provides users with the ability to incorporate extended 

services 340 designed by the third-party software developers. According to one embodiment, the 
third party developers may create network-enabling objects using the developer tools 320 (FIG. 
3A). According to another embodiment, the extended services 340 may be created by any 
generic tool for developing COM components. The use of extended services 340 provides the 

10 flexibility of later augmenting a PC A 1 00 with new network-based functionality that may be 
created or authored in the future, while still being designed in accordance with the information 
model 790 (FIG 7). This allows developers the opportunity to leverage the existing functionality 
available in the PCA extender 120 or even the user tools 330 or developers tools 320. 

The PCA extender 120, the user tools 330 and the extended services 340 are 

15 integrated or coupled to the PCA 100 through the PCA extension enabler 260. This integration 
may be achieved through standard methods of extensibility. It should be noted that the PCA 100 
may be extended through a variety of means. For example, Microsoft's products can be 
extended through an "add-in" model, where the COM object extenders, such as the user tools 
330, the extended services 340 and the PCA extender 120, are defined as add-ins at design time, 

20 through, for example, the use of a wizard or by implementing a required programming interface. 

FIG. 4 depicts one embodiment of the process for providing custom network- 
based functionality to a PCA 100 from the network-enabling software 210. The COM 
component is installed on a PC that has the PCA 100 running thereon, and may be used in 
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conjunction with the documents opened in the PCA 100. The COM component enables the 
network-enabUng objects 130 to receive the network-based functionahty in the opened document 
110. 

At step 410, the custom functionahty is authored, which may leverage 

5 functionality found in PCA extender 120, the developer tools 320 and the user tools 330. There 
are various mechanisms to create the custom functionahty, such as using Visual Basic® 
development language to create ActiveX objects, programming a component in the C++ 
language, and the hke. At step 420, the developer of the custom functionality enters certain 
custom registration information into the object created. The custom information may include, 

10 for example, properties such as an object's fixed name, display name, and Global Unique 

Identifier (GUID). This custom registration information is needed to conform the created custom 
functionality to work correctly with the rest of the invention's architecture. The custom 
registration information is used to provide a common way for all of the pieces to be able to 
communicate with each other. With correct registration information, a custom set of 

1 5 functionality can link itself to, and make use of, the PCA extender 120. The PCA extender 120 
then becomes aware of the custom functionality and the services provided, and can manage them 
appropriately. It is important to conform the created custom functionahty appropriately so that 
the PCA extender 120 can be aware of and manage the custom functionality. In one 
embodiment, the custom functionality will make use of the services offered by the PCA extender 

20 120 as well as use the PCA extender 120 to communicate with network-enabling objects 130 
within the PC document 110. 

As shown in step 430, once the authored custom functionality has the appropriate 
registration information, the functionality is packaged as a DLL file with the desired 
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configuration. Thus, if the developer wishes to deploy a plurality of DLL files in an installation 
program, the DLL files would be packaged together with an installation manager. It should be 
noted that the developer can also set other properties on the network-enabling object 130, such as 
threading models, debugging levels, and the like. 

5 At step 440, the DLL for the appropriately packaged custom functionaUty is 

provided to the user. The user may obtain the custom functionaUty in a variety of different ways, 
such as in an installation disk or Compact Disk (CD), or via download from a web site. The 
obtained DLL for the custom functionality is installed on a PC, as shown in step 450. The 
installation takes place in accordance with the developer's designed method, such as running an 

10 install program to automatically install the DLL on the PC in the appropriate location. 

At step 460, the custom DLL registers with the operating system registry, which 
allows the DLL to operate/function correctly under the COM architecture. For example, if the 
DLL is being installed on Microsoft® Windows® 3x, the DLL registers with the Windows® 

registry. The registry provides a secure, unified database that stores configuration data in a 
1 5 hierarchical form, which allows system administrators to easily provide local or remote support, 

using administrative tools. The registry also allows developers to store their own configuration 

data for their custom apphcations. 

At step 470, additional information is read from the DLL by a service manager 

that resides in the PCA extender 120. This is the information originally entered in step 420 by 
20 the developer, dictating the rules for the manner in which the custom fimctionality is to be 

utilized. 

Finally, in step 480, the service manager of the PCA extender 120 makes the 
registered DLL available to the PCA 100. It should be noted that the DLL has the necessary 
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properties, run-time information and other information needed. At this point, the service 
manager in the PC A extender 120 knows that a new set of functionahty exists and how to offer 
the functionahty to other system components. Once the PC A extender 120 is installed, the 
service manager is available. 
5 Once the necessary PC A extender 120 and developer tools 320 have been 

installed, the software developer may use these tools to author custom network-based 
functionahty that can be made available as extended services 340. 

It should also be noted that end-users will utihze the aforementioned process for 
installing the necessary user tools 330 as well as extended services 340. Once the necessary 
10 PCA extender 120, user tools 330 as well as extended services 340 have been installed, the users 
may access network-based functionality in their documents 1 10 opened within the PCA 100. 

According to the invention, and as discussed above, two logical pieces of code are 
required for operation of the invention. The first piece is the embedded network-enabling 
objects 130 and a network-enabling code 630 (FIG. 6). The second piece is the network- 
15 enabling software 210, including the PCA extender 120 and/or user tools 330 and/or developer 
tools 320. While in one embodiment, the network-enabling software 210 is an external piece of 
software that augments the PCA 100, as discussed above, in another embodiment, the network- 
enabling software 210 can be embedded into the PCA as an integral part thereof. 

FIG. 5 provides an illustration of a PCA 500 which is configured to provide users 
20 with network-based fionctionahty as an integrated feature thereof, in accordance with the present 
invention. The PCA 500 may be augmented by the use of one or more generic add-in(s) and/or 
plug-in(s) 220 that may be supplied by third-party vendors. 
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The PCA 500 comprises a native PCA code 520. The native PCA code 520 
includes code that makes the PCA 500 operational and provides the functionality and features 
that are standard for the PCA 500. The native PCA code 520 generally COmpriseS the COde that 
creates and provides the UI 522 for the underlying PCA 500. 
5 The native PCA code 520 may also include a PCA extension enabler 530 which 

allows and facilitates the use of add-in(s) and/or plug-in(s) with the PCA 500. The PCA 
extension enabler 530 is a facility that allows generic add-in(s) to plug into the PCA 500 for 
adding new functions, operations or features that were not originally available in the PCA 500. 

The native PCA code 520 may expose a native object model 540. The native 
10 object model 540 includes a description of au object architecture, including the details of the 

object structure, interfaces between objects and other object-oriented features and functions. The 
native object model 540 enables the use of an add-in 220 or any other macro or extender running 
on the PC so that the functionaUty of the add-in 220 and/or other macros or extenders can 
seamlessly be integrated into the PCA 500. The native PCA code 520 may also include an API 
15 544 to allow the PCA 500 to interact with other programs for expanding the standard features or 
providing additional functionality thereto. According to one embodiment, the API 544 is an 
integral part of the native object model 540. 

The native PCA code 520 may provide a native script engine 550. The native 
script engine 550 is a facility in the PCA 500 that executes macros or any other extenders that are 
20 to be run along with the PCA 500. 

The native PCA code 520 is provided with code that provides network 
functionality. The code for network functionahty 560 comprises a plurality of network-based 
utilities. The code for network functionality 560 may be configured to handle application 
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services, such as XML parsing and handling, session management, security, event handling and 
service management, location management, query routing, document packaging, caching, data 
initialization and persistence, command routing and other similar functions and operations that 
assist in network-based activities. In addition, the network-based utilities are configured to 
provide various optional utilities that are used to create PC documents 110 with network-based 
fimctionality therein. The network-based utilities may include layo\it utihties, forms 
management, query management, data modeler, packaging assistant, page scraping, stock quotes 
in real time, and other miscellaneous utilities and operations that assist in network-based 
activities within the spirit of the present invention. 

Using the available features of the PCA 500, one can create a new document 110 
or open an existing document 110 to perfonn operations thereon. The code for network 
functionality 560 allows users to embed network-enabling objects into the document 1 10, which 
will be described in greater detail below. Once the network-enabling objects are in the document 
110, the code for network functionality 560 allows a user to use the network-enabling objects 
and receive the network-based functionality in their documents 1 10, in addition to the non- 
network fanctionality and features provided by the PCA 500. 

FIG. 6 provides an illustration of one embodiment of a PC document 1 10 in 
accordance with the present invention. The PC document 110 comprises document code 610 and 
content 615. The document code 610 includes all computer readable instructions necessary to 
provide the PC document 1 10 with its look and feel, as well as provide support for any 
functionality embedded in the PC document 1 10. 

The document code 610 includes a script code 620. The script code allows end- 
users or developers to extend the built-in functionality of the PCA or simply create macros 
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containing often-used packaged sequences of operations (for example, repeatedly creating the 
same customized chart from a set of data). The script code 620 also may provide the abihty to 
interact with ActiveX controls and other COM components on the PC to utilize their provided 
functionahty within the PC document 110. 
5 The document code 610 may further include network-enabling code 630 for 

providing network-based functionahty within the PC document 110 at launch-time by initializing 
and launching the network-enabling object 130 to provide network-based fimctionahty. 
According to one embodiment, the network-enabling code 630 is unpacked and read by the PCA 
extender 120 at launch-time, and after that the network-enabling code 130 is not used, accessed, 
1 0 and/or read during run-time. In other words, during run-time of the network-based fimctionality, 
the network-enabUng code 630 plays no role, and is akin to not being present. The network- 
enabling code 630 is unpacked (i.e., read) at load/launch time by the PCA extender 120 to 
support the functionality of the PCA extender 120. 

The network-enablmg code 630 contains computer readable instructions for 
1 5 allowmg the initialization and/or launch of the network-based functionality as well as any other 
functions within the scope of the present invention. According to one embodiment, the network- 
enabling code 630 may include a plurality of routuies to provide different operations and 
functionahty. According to another embodiment, the network-enabling code 630 may be a 
plurality of distinct modules, separately packaged in the document code 610. The network- 
20 enabling code 63 0 may be programmed to include support for query instructions, layout 

instructions, data modehng, and various other features that may augment the PC document 110 
with additional network-based functionality. 
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According to one embodiment, the network-enabling code 630 is packed together 
in a secure location within the document code 610 of the PC document 110. In the event that the 
network-enabling code 630 is packed, it must be unpacked prior to use of network-enabling code 
630 for providing network-based functionality. Furthermore, the network-enabling code 630 
may be encrypted with a suitable encryption algorithm to ensure that the network-enabling code 
630 is tamper-proof, as well as to restrict utilization of the underlying network-based 
functionaUty to the appropriately registered modules. According to one embodiment, the 
network-enabling code 630 is packed for storage and/or transmission over a network or the 
Litemet. 

It should be noted that when the PC document 1 10 with network-based 
functionality is stored and/or uploaded, the PC document 1 10 can have a mix of packed and 
unpacked network-enabling code 630. The packed portion of the network-enabhng code 630 
requires unpacking prior to run-time of the network-based functionality. 

The content 615 in the PC document 1 10 includes data 660 and network- enabling 
object(s) 130. The data 660 may include static data 670 as well as dynamic data 680. Static data 
670, once entered, maintains its state and is often only altered by a user. Dynamic data 680, on 
the other hand, may be added and/or altered at any time, possibly without any active intervention 
by a user. For example, the PC document 1 10 could be configured for allowing the dynamic 
data 680 to be altered in real-time by content from the Memet or other networks by providing a 
real-time stock feed into the PC document 110. 

It should be noted that according to one embodiment, the content 615 may also be 
provided as a mix of packed and unpacked content in addition to the network-enabling code 630. 
For example, where it is desired that the user not be able to access certain pieces of content, the 
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content may in fact not get completely unpacked at runtime. Similarly, it is possible to not 
unpack part of the network-enabling code 630 to deprive an unlicensed user of its functionality, 
and the still-packed code 630 would be inert and not executable at runtime. Additionally, it is 
possible to pack the content 615 in an encrypted format. 
5 The network-enabling object 130 may be embedded as part of the content 615 of 

the PC document 110. As part of the invention's distributed architecture, the network-enabling 
object 130 may be able to communicate with the script code 620. Through the script code 620, 
the network-enabling object 130 may communicate with the PC A extender 120, and the PC A 
extender 120 then communicates with the network-enabling code 630. It should be noted, that 
10 the network -enabling object 130 is also capable of interacting directly with the PCA extender 
120. 

According to one embodiment, the network-enabling object 130 may be a self- 
contained packaged set of functionality. According to another embodiment, the network- 
enabling object 130 will operate in conjunction with the PCA extender 120 and other custom 
15 functionality that persists on the client, such as user tools 330, developer tools 320 and/or other 
add-ins. 

According to the invention, the developer may leverage the distributed 
architecture and decide how "heavy" to make the network-enabling object 130 portion of the 
code, by providing all the requisite code for receiving network-based functionality as part of the 
20 network-enabling object 130. The developer can decide the amount of functionality to be put 

into the network-enabling object 130, versus putting the network-based functionality as a custom 
add-in. The best balance will depend on the particular functionality being deployed, and perhaps 
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even on deployment issues such as code size for add-in code being downloaded from the Internet 

for installing on the client. 

FIG. 7A-7D provides an illustration of different states of communication between 
the PC document 110 with one or more controls external thereto. According to an embodiment 
of the present invention, the PC document 110 comprises a wireframe 705, which has content 
61 5, native script code 620 and network-enabling code 630. The content 615 comprises user 
interface (UI) 710, which has information regarding formatting and layout for the data 660 and 
the objects 130 therein. The UI 710 essentially provides the look and the feel of the content 615. 
For example, the UI 710 confrols the fonts, formatting and the layout of text in the PC document 
1 10. The content 615 further includes configuration 720, which enables and facilitates the user's 
viewing thereof For example, the configuration 720 may allow a user to decide the zoom-in 
level of the PC document in a Microsoft® Excel spreadsheet. 

As noted above, the content 615 includes static and/or dynamic data, depending 
on the choice of the user. In addition, the content 615 is provided with network-enabhng objects 
130 for launching network-based ftinctionality from within the PC documents 1 10. 

According to the invention, the native script code 620 provides the ability to 
interact with ActiveX® confrols and other COM components on the PC to utilize the network- 
based functionahty within the PC document 110. The native script code 620 permits the PCA 
100 to leverage its core ftinctionality and permits the PCA 100 to provide network-based 
ftinctionality from within the PCA 100 environment. While there are various network-based 
fiinctionahties that can be provided, they may include communications services that allow a user 
to communicate and interact with others, sfreaming services that allow a user to receive and play 
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streaming content, data services that allow a user to retrieve, manipulate, and view data retrieved 
over a network, as well as various other services within the scope of the present invention. 

According to one embodiment of the present invention, the native script code 620 
allows any of the network-enabling objects 130 in the PC document 1 10 to interact with the PCA 

5 extender 120 running alongside the PCA 100. More particularly, external components 

communicate with the network-enabling objects 130 via the PCA extender 120. While this is 
one mechanism of operation, it should be noted that the present invention also allows the PCA 
extender 120 to directly communicate with the network-enabling objects 130, without requiring 
any intervention from the native script code 620, according to another embodiment of the present 

10 invention. 

The network-enabling code 630 facihtates the providing of network-based 
functionality within a PC document 1 10. The network-enabling code 630 contains computer 
readable mstructions for launching network-based functionality as well as any other functions 
within the scope of the present invention. The netwcrk-enabhng code 630 may be programmed 

15 to include support for query instructions, layout instructions, data modeling, and various other 
features that may augment the PC document 110 with additional network-based functionality. 
As noted above, the network-enabhng code 630 may be packed in a secure location within the 
document 1 10, in which case it must be unpacked prior to its use. Furthermore, the network- 
enabling code 630 may be encrypted. 

20 According to the invention, the native script code 620 is capable of 

communicating with the PCA extender 120 or other extemal COM components 780 or ActiveX 
controls 770. According to the invention, there are different models according to which the 
network-enabling objects 130 may interact with the PCA extender 120 to provide network-based 
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functionality, as shown in FIGS. 7A-7D. Accordingly, a developer may extend and customize 
the PC A extender 120 in a variety of ways to provide any additional type of customized 
functionality. 

When designing additional ActiveX 770 and/or COM controls 780, the developer 

5 can have them work in conjunction with network-enabUng objects 130, allowing the PCA 100 to 
become a distributed application. The developer has the flexibility to design and provide 
network-based functionality in different ways, since they can utiUze the PCA extender 120, or 
they can provide the network-based functionality via the native script code 620. According to 
one embodiment, a part of the distributed PCA manifests itself as the network-enabling object 

10 130 and another part takes the form of an ActiveX control 770. According to another . 

embodiment, another part of the distributed PCA could be a COM control 780 that leverages 
flinctionality available in the PCA extender 120, 

FIG. 7 A provides an illustration of the present invention at launch-time of the 
network-based functionality. Initially, network-based functionality is launched when the PCA 

15 extender 120 reaches into the PC document 1 10 and unpacks (i.e., reads) the network-enabling 
code 630. The infomiation from the network-enabling code 630 is stored in the PCA extender 
120 which allows it to provide the appropriate network-based functionahty at runtime. It should 
be noted that the PCA extender 120 is not supported by the other external COM components 780 
or ActiveX controls 770, initially. Furthermore, in this embodiment, the PCA extender 120 does 

20 not need to communicate with the native script code 620 to unpack the network-enabling code 
630. 

As shown in FIG. 7B, according to one embodiment, the network-enabling object 
130 communicates with the PCA extender 120 to provide network-based functionality in the PC 
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document 110. According to this embodiment, the network-enabUng object 130 is provided with 
the necessary code to interact with the PC A extender 120 to launch, obtain and utihze the 
network-based functionahty within the PC document 110. It is possible for the PCA extender 
120 to interact with the COM component(s) 780 to seek additional functionality not available in 
5 the PCA extender 120, as indicated by the instructions contained in the network objects code. It 
should be noted that the network-enabling code 630 play no role in the process. According to 
this embodiment, the native script code 620 is not necessary for providing the network-based 
functionahty. 

As shown in FIG. 7C, according to another embodiment, the PCA extender 120 
10 communicates with the network-enabling object 130 to provide network-based functionahty in 
the PC document 1 10. Furthermore, the PCA extender 120 may interact with the COM 
ccmponent(s) 780 to seek additional functionality not available in the PCA extender 120. Based 
on the operations and features of the PCA extender 120 and/or the COM components ^80, the 
native script code 620 may be provided with the requisite information to allow it to communicate 
15 with the network-enabhng objects 130. According to one embodiment, the native script code 
620 can communicate directly with the ActiveX 770 and/or COM controls 780 to provide 
additional functionality not available through the PCA extender 120. As a result, the network- 
enabling objects 130 may provide network-based functionahty in accordance with the PCA 
extender 120 as well as the ActiveX 770 and/or COM controls 780. 
20 As shown in FIG. 7D, according to another embodiment, the network-enabhng 

object 130 communicates with the PCA extender 120 to provide network-based functionality in 
the PC document 110. Furthermore, the information from the unpacked network-enabling code 
630 that is read by the PCA extender 120 provides the requisite information to the native script 
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code 620, and creates and provides the necessary information to an information model 790. 
Where the network-enabling code 630 is provided packed, the PCA extender 120 unpacks the 
network-enabling code 630 prior to launch to read the necessary information therefrom and 
create the information model 790. The information model 790 is a holding area that houses 

5 information about the functions the PC document 110 is supposed to support at runtime, and the 
methodology^ for running the functions. For example, the information model 790 might contain a 
query definition of how to retrieve stock quote information, namely the server to look for, the 
data param.eters to retrieve, and the mechanism for handling the resulting data sets. 

The information model 790 interacts with the network-enabling objects 130 to 

10 provide the appropriate netw^ork-based functionality within the PC document 110. 

Since network-based functionality may be distributed between network object 130 
and Com component 780, the desired network-based functionality can be authored by a 
developer according to the best suited structure. A developer may choose to place more 
functionahty in COM component 780, resulting in a "hghtweight" network-enabling object 130. 

15 This allows easier distribution of the PC document 110 once the base COM component 780 has 
been installed. 

FIG. 8 is a schematic flow diagram depicting the process for creating a personal 
computer document with network-enabling objects embedded therein. In general, the objects 
130 may be embedded into PC documents 1 10 in several ways. They can be placed into 
20 documents by developers, and the documents can then be posted on a web site or e-mailed to 
users. When coupled with the ability to control and manage the behavior of the containing 
application, this basically provides for the development of powerful, distributed "embedded 
applications" that are essentially defined by the combination of the containing appHcation and 
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the enhanced document within it. Alternatively, the network-enabling objects 130 can be made 
available to end-users and stored on end-user systems. End-users can then place objects 
personally into individual PC documents 1 10 they create or receive. This capabihty can be used 
in combination with other hitemet or network functions. 
5 The present invention may also be used to provide professional developers with a 

tool set for creating PCA-based services and appUcations, such as "PC Apphcation Web Sites." 
While certain development capabilities may best be provided through a specific, separate 
apphcation program for developers using the technology, many capabilities may be provided to 
developers through an extended version of the target PCA itself. Thus, for example, this will 

10 allow a high fraction of web site development to be conducted using the famihar, functionally 
rich, and domain-specific environment of a PCA rather than traditional web site development 
tools or lower level development environments such as C or Java. This will facilitate the 
workflow processes associated with web site development, by permitting partially completed 
PCA-based web sites to be e-mailed, viewed, and edited by multiple developers and end-users, 

1 5 using augmented versions of a single PCA. Moreover, where business rules can be defined using 
the built-in script and/or native functionality of the document and desktop application, parts of 
the PCA-based web site can essentially be coded directly by domain experts (i.e., end-users) 
rather than passing specifications off to a developer for implementation, thereby potentially 
reducing development time and cost. 

20 Referring to FIG. 8, at step 810, the PCA 100 is launched, along with the 

network-enabling software 210. According to one embodiment, because of the appropriate 
configuration of the network-enabhng software 210, it automatically launches when the PCA 
100 is launched. At step 820, the PC document 1 10 is opened. According to the invention, the 
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PC document 110 may be new and completely blank, initialized through a pre-defined template, 
or a pre-existing document. 

Once the PC document 1 10 is open, data may be created therein, as shown in step 
830. For example, content for a word processing document may be entered by the user. As 

5 noted above, the data may be static or dynamic. In step 840, network-enabling objects 130 are 
embedded as part of the content 615 of the PC document 1 10, There are a variety of ways in 
which users may be allowed to embed the network-enabling objects 130 in the PC document 
110. According to one embodiment, the user is provided a toolbar as the UI of the network- 
enabling software 2 1 0, from which the user can simply choose the desired network-enabling 

10 object 130, and then drag and drop in the appropriate location of the PC document 1 10. 

As one embodiment, the system allows a user to encrypt the network-enabling 
code 630, in step 850. In step 860, the network-enabling code 630, which may or may not be 
encrypted, is placed in the document code 610 area of the PC docimient 1 10. According to one 
embodiment, the network-enabling code 630 may be packed in a hidden area so that it is 

15 invisible to the user. According to another embodiment, the network-enabling code 630 may be 
compressed before being placed in the document code 610 area of the PC document 110, 

Finally, in step 870, the PC document 870 is saved on the local system. As the 
above discussion shows, the saved PC document 110 comprises data as well as network-enabling 
objects 130 and network-enabling code 630. During runtime, the network-enabling objects 130 

20 and the native PC A code 230 interact with the network-functionality software 210 to provide 
network-based functionality in the PC document 1 1 0. 

FIG. 9 provides one embodiment of the process for loading the PC document 110 
with network-based functionaUty therein. At step 910, the PC A 100 is launched by a user. As 
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depicted in box 920, once the PCA 100 has been launched, the user opens a standard document 
for the launched PCA 100. For example, if the launched PCA is Microsoft® Excel, then the 
open document will be an Excel spreadsheet or any other compatible Excel file type. 

At step 930, the installed PCA extender 120 detects the opening of the PC 

5 document 110. At step 940, the installed PCA extender 120 inspects to determine if the PC 
document 110 has the appropriate network-enabhng objects 130 and the network-enabhng code 
630 therein for providing network-based functionality within. At step 950, based on the 
inspection in step 940, the system determines whether the PC document 1 10 has the appropriate 
network-based functionahty therein. If the system determines that the launched PC document 

10 110 does not have the requisite network-based functionahty, then the PC document is opened 
with no intervention from the PCA extender 120, as shown in step 960. 

On the other hand, if the system determines that the launched PC document 110 
has the requisite network-based functionality therein, then the network-enabling code 630 is 
located by the PCA extender 120 in step 965. If the network-enabling code 630 is encrypted, 

15 then the PCA extender 120 causes decryption of the network-enabling code 630 to read it, as 
shown in step 970. At step 980, the system initializes and launches the PC document 110 along 
with the network-based functionality in accordance with the activation of the network-enabling 
objects 130 and/or the instructions provided in the network-enabhng code 630. 

FIG. 10 provides an exemplary illustration of a client/server architecture utilizing 

20 the network-enabhng features provided to the chent, in accordance with the present invention. A 
client 1000 hosts the underlying PCA 100. The PC document 1 10 is launched within the PCA 
100. As noted above, the PC document 1 10 is provided with one or more network-enabhng 
objects 1 30, which communicate with the PCA extender 120 running with the PCA 100. 
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The client connects to a network 1050 for receiving the network-based 
fiinctionahty for which the network-enabling objects 130 are configured. Using the network 
1050, the client 1000 may connect with one or more network servers, such as a web server 
extender 1060 which runs on a generic web server 1065, or a speciahzed server(s) 1070 and/or 

5 one or more generic third-party servers 1080 for real-time feeds. In one implementation, the 
chent 1000 may be provided with one or more communication means for connecting and 
interacting with the network 1050. The communication means is coupled to a central processor 
on the client machine. The scope of the present invention is not hmited by the choice of 
communication means employed. Accordingly, it is possible to use one or more modems, a 

10 DSL, an ISDN, a cable modem or any similar device to connect to the server and communicate 
therevv'ith. 

The cUents are able to connect to the server and receive their network-based 
functionality. For example, a client 1000 may connect to a web server extender 1060 which 
connects Co a generic web server 1060 for receiving regular feeds about fluctuations in the stock 

15 market, or connect to the specialized server(s) 1070 that provide specialized services to the 
chent, such as real-time feeds 1085, collaboration support 1090, data access 1095, workflow 
servers, hcensing ser/ers and the hke. If a chent connects to the generic third-party servers 1080 
for real-time feeds, the client system is provided with speciahzed network-based ftmctionahty in 
the PC document 110 that allows the extended PC apphcation 100 to utihze the real-time feeds 

20 within the PC documents 110. 

It should be noted that the chent/server architecture of FIG. 10 can be utilized to 
download individually or collectively the PC A 100, the PC document 110, network-enabling 
software 210, and/or the network-enabling object 130 from the Internet or some other compatible 
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network. For example, a request for a download may be received at the web server extender 
1060 which appropriately transmits it to the web server 1065, or the request may be received at 
the specialized server(s) 1070. Accordingly, the client may transmit a login request, and then 
make a request to download the desired component(s) of the present invention. The request is 

5 appropriately handled at the receiving server, and the request is processed by the server. Finally, 
the server serves the requested component(s) of the present invention to the remote client. 
According to one embodiment, the cHent may be required to authenticate its identity prior to the 
server serving the requested component. 

The web server extender 1 060 may be utilized for custom request handling of 

10 chent requests. According to one embodiment, the custom request handling may be 

authenticating the remote chent. According to another embodiment, the custom request handling 
may be deciding the version of the requested component(s) to be served to the remote client. 

For example, web server extender 1060 may provide intelligence to determine 
appropriate version of a financial data sheet to return to a client - either a PCA spreadsheet 

1 5 version or an HTML web page version. 

FIGS. 1 lA-llB provide an illustration of the present invention where PC 
documents are provided with network-based functionality therein. It should be noted that the PC 
documents described in FIGS. 1 1 A-1 IB are merely two embodiments of the present invention, 
and various other embodiments may be constructed using the disclosed invention. 

20 As shown in FIG. 1 1 A, the PC document 1 100 relates to a financial spreadsheet 

with complete information of a user's finances and comprises various components as part of its 
content. At the top of PC document 1 100, there is a page title 1 105, which is a part of the static 
data. The content further comprises summary chart 1110, which contams information regarding 
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a plurality of financial accounts held in the user's name. Each financial account is listed 
individually, and may be provided as a link to another document, web site, page within the same 
document- and/or application to provide users with more detailed information for each entry. 

The content may also include formulas that compute mathematical values, such as 

5 the one shown as the total current value 1 120. According to the present invention, various charts 
providing gi'aphical depictions 1 125 of the data shown in the summary chart 1110 may be 
provided as part of the content of the PC document 1 100. 

According to the example depicted in FIG. 1 1 A, each of the financial accounts are 
provided as a link to another account accessible over the network. Thus, cUcking on E*TRADE 

10 takes users to the appropriate page that maintains information about the user's stock portfolio; 
clicking on Citibank Checking takes users to the appropriate page that maintains information 
about the user^s bank account; clicking on Citibank Visa takes users to the appropriate page that 
maintains information about the user's credit card, and similarly other links transport the user to 
the appropriate page. 

15 FIG. 1 IB provides an illustration of a PC document 1 130 that contains a plurality 

of network-based functionalities therein for providing information regarding the user's stock 
portfolio. As shown in FIG. 1 IB, the PC document 1 130 relates to a financial spreadsheet with 
complete information of a user's stock portfolio. The PC document 1130 comprises a wireframe, 
population data, and form data. The wireframe includes static content and native script code that 

20 is generally not modified during runtime within a PCA residing on an end-user's system. 

Population data is dynamically generated data used to populate specified areas 
within a wirefi*ame during the PCA's runtime. Generally, population data is supphed by a server 
and is designated "read only" and is not ahered. Population data may be used to populate fields, 
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strings, and pick lists for display to the user, or transparently as calculation data operated on by 
the apphcation. Population data may also be defined to be a function of information maintained 
in the associated wireframe, user input, or both, and may typically be generated or retrieved upon 
actions such as startup, connection, form submission, or in real-time in response to remote data 
5 changes. 

Form data is data that is specified or manipulated at the client computer by users 
during runtime for the eventual purpose of transmission to a server. Form data is usually one- 
way data transmitted from client to server. But in some circumstances it may be desirable to 
read such data from a server (for example, as cached prior information to pre-populate a user 

10 form or as smart defaults for a user form) to pre-fill forms within a wireframe. Form data 

includes data items, such as data entered into text box prompts (for example, asking for a user's 
usemame and password for authentication) and parameterized data entered into defined queries 
(such as stock ticker symbol as a parameter in a we b query). 

The PC document 1130 comprises a market chart 1135 that is connected to a 

1 5 network so that it receives historical data for the market index in real time. The market chart 
1135 forms a part of the population data that is read-only and cannot be changed by the user. A 
toggle button 1 140 is provided to switch the market chart 1135 between display of historical data 
for each of the selected indices. 

The PC document 1130 further includes a portfolio table 1 132 for the user, which 

20 contains detailed information regarding the various stocks owned by the user. The portfolio 
table 1 132 has layout definition as part of the wireframe, and includes static data such as the 
heading "Portfolio", heading for various columns, such as "Symbol," "Current Price ($)", and 
the hke, as well as native script code that is not visible to the user. The native script code 
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includes instructions for fetching the information regarding the stock's trading volume, stock's 
price, number of shares owned and the hke, based on the identity of the user. Information 
regarding shares owned by the user represents form data and is transmitted from the chent 
computer to the server. On the other hand, displayed information regarding stock's price is 

5 population data and is supphed by the server to the chent user; this information is read-only. 

Network-enabling objects in the form of Alert Wizard button 1 142 and Trade 
button 1 144 are provided in the wireframe. The user may click the Alert Wizard button 11 42 to 
launch a network-based functionality that allows the user to receive appropriate alerts and 
notifications on a regular basis. The user may click the Trade button 1 144 to launch a network- 

1 0 based functionality that allows the user to make stock trades over the network. Behind-the- 
scenes functionality, e.g. trades, is provided either by the PCA extender 120, network-enabUng 
object 130, or by a custom COM object. 

Furthermore, the PC document 1 130 includes a web browser 1 150 that is 
embedded in the PC document 1 130 in accordance with the present invention. According to the 

1 5 invention, the web browser 1 1 50 is a network-enabling object that brings network-based 
functionality within the PC document 1 130. , 

FIGS. 12A-12E are screen-shots of a personal computer document 1 10 
augmented with developer tools 320 in accordance with the present invention. 

FIG. 12A shows an open PC document 110, which is a spreadsheet in the present 

20 example, with developer tools 320 available within the PCA being used. As shown in the FIG. 
12 A, the developer may decide the appropriate data model for the PC document 110 being 
created, and/or perform desired operations therein, such as XML queries, web data queries, page 
scraping, database queries and the like. 
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FIG. 12B shows the open PC document 110 with developer tools 320 available 
within the PCA being used. As shown in the FIG. 12B, the developer may decide the type of 
forms to be created for the PC document 110 being created, and/or choose the information to be 
provided in the form, such as stock information and the like. 

5 FIG. 12C shows the open PC document 110 with developer tools 320. As shown 

in the FIG. 12C, the developer may decide the appropriate action for objects therein, such as 
packing and/or unpacking, deploying web pages and the like. 

FIG. 12D shows the open PC document 1 10 with developer tools 320. As shown 
in the FIG. 12D, the developer may create widgets for use in the PC document 1 10, such as a 

10 facihty to allow chat in the PC document 1 10. 

FIG. 12E shows a v/orkboqk behavior tool 1200 as a developer tool for 
determining and/or controlling the behavior of data and/or other content in a spreadsheet 
workbook. The behavior tool 1 200 allows setting of options to control the environment of the 
PCA 100 at run-time (e.g., locked areas, scratch sheet areas of the spreadsheet, etc.). 

1 5 FIG. 13-15 illustrate one exemplary embodiment for a system and method for 

both developing and accessing a web page as an embedded application that can be produced 
using an augmented spreadsheet program and an enhanced spreadsheet document. An example 
of such an enhanced spreadsheet in provided in FIG. 1 IB. 

FIG. 13 is an illustration of a client/server architecture in accordance with one 

20 exemplary embodiment of the present invention, which provides a system and method for both 
developing and accessing a web page as an embedded application that is produced using the 
spreadsheet program 1300 that has been extended with a network- functionahty software 1320 
and a network-enabled spreadsheet document 1310. The embedded application web page allows 
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an end-user to enter a stock's symbol, receive relevant historical data relating to the stock via a 
web server, and chart the received data within the embedded application web page using the 
built-in charting facilities of the host spreadsheet apphcation 1300. 

The developer's system comprises a developer cHent computer 1302 that is 

5 connected to network 1304 via a communication link 1306. Network 1304 may, for example, be 
a private intranet, a virtual private network, or the global Internet, and the conamunication 
protocol used on the network may be TCP/IP or any protocol layered on top of IP, such as 
SMTP, FT?, HTTP, etc. In this example, the developer chent computer 1302 is provided with a 
spreadsheet software program 1300, such as Microsoft EXCEL or Lotus 123, The client 

10 computer 1302 is also preferably provided with a developer's network-functionality software 
1320 that adds tools and/or provides fimctionality to the spreadsheet softvvare 1300 to facihtate 
the creation of spreadsheet web pages, and an end-user's network-fiinctionality software 1350 
for providing runtime support for the network-based functionality within the spreadsheet 
documents. 

1 5 The developer is connected to a web server 1 3 1 4 via the network 1 3 04. The web 

ser/er 1314 is connected to the network 1304 via a communication link 1316. Web server 1314 
provides access via said network 1304 to one or more web pages 1334 or customized embedded 
application web pages 1336. The original spreadsheet document is now a custom embedded 
application 1336. Web pages 1334 or customized embedded apphcation web pages 1336 can be 

20 stored locally or any place on any network that the web server 13 14 can access. 

The end-user's system comprises a client computer 1340 that is connected to the 
network 1304 via a coramunication hnk 1306. The chent computer 1340 is provided with end- 
user's network- functionahty software 1350, which may include user tools and a PC A extender. 
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It should be noted that the developer is provided with tools that may be distinct 
ja-om those provided to a end-user, because the developer uses the system to create an embedded 
apphcation web page 1336, while the end-user uses the system to access and interact with that 
embedded application web page 1336, 

5 In summary, the present system and method relates to a developer at cHent 

computer 1302, who identifies an HTML page 1334 to be rendered as an embedded apphcation 
web page. The developer imports a snapshot of the HTML page 1334 into spreadsheet software 
1 3 00 and onto the first sheet of a new spreadsheet 1 3 1 0, The developer may then modify the 
web page's layout to improve its appearance so that it is more appropriate to a spreadsheet-based 

10 apphcation. 

The HTML page being rendered will typically include some content that changes 
infrequently, if at all, and other data or content that changes in response to user actions, remote 
data updates, and so forth. For example, a web page maintained by an information provider that 
displays stock prices information will generally include some information that remains 

15 essentially constant, such as the page layout, information provider's name and logo, and other 
information that requires frequent updating, such as stock prices and performance data. The 
present invention distinguishes between these "static" and "dynamic" content elements, and 
manage them in different ways. 

The static portions of the HTML Web page are preferably rendered in the 

20 spreadsheet version of the page as static data within one or more cells or controls within the UI 
of the embedded application web page. In one embodiment, static HTML text and images may 
be incorporated in the spreadsheet docimient using the base HTML import operation of 
spreadsheet software 1308, if included. 
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According to one embodiment, the dynamic portions of the HTML Web page are 
rendered as one or more named cells, charts, or other controls. The developer links these UI 
elements to state-information elements that may, for example, be stored in cells on a second 
spreadsheet page or elsewhere in computer memory. These state-information elements can 
5 themselves be linked to one or more queries stored, for example, in cells on a third spreadsheet 
page or elsewhere in memory or the information model 790. At runtime, these queries are 
executed and the query results are stored as state information in the linked state-information 
elements. This state-information is then used to populate the dynamic portions of the 
spreadsheet web page. 

TO Tt may also be desirable to include form elements to allow an end-user to enter 

'Torm data," such as the stock symbol whose price the end-user wishes to retrieve. These form 
elements are preferably rendered as one or more cells or other controls, such as entry fields, pick 
lists, and the like, on the first spreadsheet page 1310. The developer links each such UI form 
element to one or more state-information elements preferably stored in cells on the second page 

15 of the spreadsheet 1320 or elsewhere in memory. Information entered by a user in a form 

element on the first spreadsheet page is passed back to these linked state-information elements 
for further processing or transmission to web server 1314. 

The developer then refines the embedded apphcation UI by hiding distracting 
elements that will not be needed by end-users in typical operation of the page 1310, such as 

20 secondary scratch sheets and extraneous toolbars. Using tools provided by the invention, the 
developer may decide to restrict or otherwise control the extent to which an end-user may 
modify or interact with the new web page. The embedded apphcation web page 1310 is then 
placed into run mode which may prevent any disruption of the UI by end-users. The completed 
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enhanced spreadsheet web page 1310 is then posted to web server 1314 as custom embedded 
web page 1336. This deployment may include providing hnks to the embedded application web 
page 1336 from other pages, such as the HTML page 1334, on the same or other web sites. 

An end-user at end-user computer 1340 may download the embedded apphcation 

5 web page 1336 from web server 1314 by opening the page in spreadsheet software 1 360 directly 
or by its hyperlink, which also causes the page to automatically be opened in spreadsheet 
software 1360 as the enhanced spreadsheet document 1370. The network- fimctionality software 
1350 and the runtime code in the enhanced spreadsheet document 1370 cooperate to execute any 
queries to retrieve population data elements as specified by the developer. The contents of these 

10 elements are used to populate the dynamic data regions of the first spreadsheet page 1370, which 
may then be displayed to the end-user. 

While viewing the enhanced spreadsheet document 1370, the end-user has 
available all functionahty provided by spreadsheet software 1360 that the web page developer 
has left accessible. For example, if the displayed page contains raw stock data, the end-user may 

15 use the spreadsheet software's chart fimctionahty to create a chart from said data. In addition, a 
scratchpad area may be provided on an additional sheet of the spreadsheet that allows the user to 
perform arbitrary calculations and manipulations based on the data displayed on the web page. 
The end-user may also link to data on the web page from a second spreadsheet or other program 
running on end-user computer 1340. Furthermore, if the user enters a new stock symbol to be 

20 chaited, the relevant data will be returned to the client via a population data query and charted, 
causing only the updated areas of the client-side embedded web page 1370 to be updated. As a 
result, the present system provides high update and refresh performance. It should be noted that 
custom analysis can be performed locally as opposed to constant calls to the network. 
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FIG. 14 provides a provides a detailed flow of the operation by a developer to 
create a web page in accordance with the present invention, using a spreadsheet application 1300 
that has been provided with a network-functionality software 1320. In step 1402, the developer 
launches spreadsheet application 1300. Launching the spreadsheet application 1300 also 
5 launches the network-functionality software 1 320, including the developer tools and user tools. 
In this embodiment, developer tools of the network- functionality software 1320 add a 

developer's toolbar to spreadsheet software 1300 for inserting macros and UI elements into the ■ 

spreadsheet document 1310. These tools may be made available on one or more developer's 
toolbars or menus that become embedded in the software's UL 

10 m one embodiment, the toolbar may include a "new Web page" button for 

creating a new spreadsheet web page by providing a rendering of a web page as an enhanced 
spreadsheet document. In step 1404, the developer clicks on the "new Web page" button. In . 
step 1406, the system presents to the developer a wizard containing a palette that displays a 
selection of templates for designing a web page. In addition, the wizard includes a "browse to 

1 5 web page" button. 

According to the present invention, it is assumed that the developer wishes to 
create a spreadsheet web page that "mirrors" an existing browser-based page, rather than create a 
spreadsheet web page from scratch. Accordingly, in step 1408, the developer clicks on the 
"browse to web page" button on the developer toolbar. In step 141 0, a browsing window pops 

20 up within the spreadsheet's UI and the developer browses to and selects the web page that the 
developer wishes to copy. According to one embodiment, the developer browses to a web page 
1334 displaying stock price performance. An example of such a web page can be seen at 
http ://quote .yahoo .com. 
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In step 1412, a snapshot of the selected web page is imported onto the first sheet 
of the spreadsheet document 1310. This step may employ the native HTML import functionality 
of the spreadsheet appHcation 1300. 

As those skilled in the art will recognize, the native HTML import functionality of 
5 spreadsheet programs typically create layout errors, including overlapping and obscured items. 
Consequently, in step 1414, the developer may be provided with a tool for cleaning up any 
layout problems created by the format translation. Altematively, the developer tools in the 
network- functionahty software 1320 may be provided with its own HTML import functionality 
that does not introduce these layout problems. However, it should be noted that the developer 
10 laying out a spreadsheet web page should preferably visualize the page in terms of the optimal 
layout for the spreadsheet application environment, rather than attempting to copy exactly the 
look and feel of the page's browser-based version. However, this should preferably also be 
balanced with the desire to maintain as consistent a look and feel between the two versions as • 

possible. 

15 In step 1416, the developer defines state information associated with the 

embedded appHcation web page 1310. Each state-information element is implemented as a 
named property, using developer tools provided to create and manage the properties. These 
elements may be stored as data values in spreadsheet cells on a second spreadsheet page that is 
accessible to the developer but may not be accessible to the end-user. Altematively, state 

20 information may be stored elsewhere in memory or the information model 790 and referenced 
only by name. Using the state-information manager, the developer defines individual properties 
of the state information element and optionally specifies a data type, such as string, numeric, 
dollar, date, and the like, and a default value for the property. Once defined, the document code 
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in the spreadsheet document 1310 and/or network-functionality software 1350 allows the 
element to be referenced elsewhere in the appHcation by property name. 

In step 1418, the developer uses the developer tool that is provided to define one 
or more queries for retrieving dynamic data at runtime. These query specifications may be static, 
5 i.e., contain no variables, or may alternatively be a function of one or more named state- 
information elements. These queries and query results may also be located in cells on a third 
spreadsheet page or alternatively stored elsewhere in memory. 

A query manager may be provided as a developer tool, for facilitating the creation 
and management of these queries. When the developer wishes to define a query, the query 

10 manager creates a new data item and displays a dialog box that prompts the developer to enter 
the desired query. For example, if the developer wishes to create a query that retrieves the stock 
price information, the developer might enter the URL query that looks like 
http://lios t.c nbc.cora/ietson/Chart.html?SYmbol-%stock$vmbol%+data=raw and specify that 
data returned by the query should be stored in a data item, that may be labeled StockData. 

15 In the above query, the "%stocksymbol%" sub-string indicates that the cxirrent 

\alue of the StockSymbol state-information element should be substituted into the query before it 
is executed at runtime. This symbol substitution and name reference capabiUty is provided to the 
end-user by user tools in the network-functionahty software 1350. The "data=raw" sub-string 
indicates to the web server that it should return the raw data, possibly encoded in an HTML 

20 table. At runtime, the query will be executed by end-user network-fimctionality software 1350 
and the returned data stored in the StockData data item, which may then be referenced by name 
in other fields and controls in spreadsheet document 1310. 
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In addition, the query manager may be adapted to automatically create a query to 
retrieve data identified by the user. According to one embodiment, the query manager may 
permit a developer to direct a browser to a web page and select, for example, a field on the web 
page with a mouse. The query manager may then automatically formulate an appropriate query 
5 for retrieving data through end-user tools in the network-functionality software 1350. 

In step 1420, the developer links dynamic-data and form-data values and other 
fields on the first spreadsheet page to particular state-information or user interface elements. For 
example, the developer may link the Stock Symbol property defined above to the entry field on 
the spreadsheet web page. It should be noted that the system may be adapted to allow these 
10 elements to be referenced by name in formulas and macros so that the developer need not be 
aware of where or how they are stored. 

[n step 1422, the developer creates the spreadsheet application-based chart that 
will replace the static image used in the original HTML page, which is generated during the 
import step 1412. In particular, the developer deletes that static image fi-om the first page of the 
15 spreadsheet document 1310, selects the area of the page that the chart should occupy, and 
launches the chart wizard of the spreadsheet application 1308. In the wizard, the developer 
selects one ot the standard hne or area charts and then specifies the data source for populating 
the chart, which in this case is the StockData data item described above. This connects the chart 
to the d>'namic data stored in the StockData data item. The developer then sets the chart's 
20 display properties, such as scaling, labels, axis details and so forth, as desired. 

In step 1424, the developer may lock or otherwise disable portions of the UI that 
will be presented to end-users when spreadsheet document 1310 is opened during runtime. 
During this step, the developer selects areas of the first spreadsheet page that should be read-only 
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and presses a ''freeze" button on the developer's toolbar. This locks the selected portions of the 
page so that they cannot be selected and manipulated by the end-user. Also during this step, the 
developer may specify spreadsheet pages as invisible to the end-user. In the present 
embodiment, the developer will typically designate only the first spreadsheet page as visible. In 
5 addition, the developer may v^ish to hide any standard spreadsheet toolbars that are inappropriate 
for the particular spreadsheet wch page. 

In step 1426, the developer presses a mode toggle button provided on the 
developer toolbar, causing the end-user tools to take over the spreadsheet application and enforce 
the embedded appUcation web page behavior that has been designated by the developer. The 
1 0 developer may then work locally on the cUent machine with the web page in runtime mode to 
verify that the embedded appUcation web page functions properly. 

In step 1428, the developer posts the spreadsheet application web page to the web 
sender 1314 and provides a link to the page to allow end-users to access it. For a more seamless 
and integrated experience, the developer may additionally utihze a redirector module that runs on 
15 the web server in response to end-user requests for the stock web page and transmits either the 
browser version or spreadsheet version of the web page to a particular end-user based on any of a 
number of possible criteria. 

FIG. 15 provides a detailed flow of the operation by a user to use a web page 
created in accordance with the present invention. In step 1502, the end-user clicks on or 
20 otherwise opens the hyperlink associated with the spreadsheet web page 1336. This hyperlink 
may be a direct link to the enhanced web page 1336 or a link that invokes redirector software at 
Web server 1314. In the latter case, the redirector software can retum either the browser web 
page 1334 or the enhanced spreadsheet page 1336 based on either client capabilities - namely, 
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whether or not spreadsheet application 1300 and end-user network-functionahty software 1350 
are available on chent machine 1340 - or on preferences for the specific end-user. Such 
preferences may be based on the type of enhanced document or on the particular page or on the 
web site as a whole or upon other controlling criteria. The page is transmitted to end-user client 
5 machine 1340 in step 1504 and automatically opened within spreadsheet software 1360, Where 
enabled, this operation may open the spreadsheet apphcation within the launching browser 
container using available systems mechanisms such as Active Document Servers and multiple- 
document interfaces (MDI). 

In step 1506, end-user network-functionality software 1350 and runtime code in 

1 0 the downloaded embedded application web page 1 370 cooperate to execute any queries in the 
web page and to store the returned data in one or more population data elements. In step 1508, 
this state information is used to populate any designated dynamic-data regions of the first 
spreadsheet page. In step 1510, the complete "web page" is displayed to the end-user in the PCA 
fonnat. As noted above, while viewing the page, the end-user has access to all built-in 

15 spreadsheet functionality of spreadsheet software 1360 allowed by the developer. As a result, 
the user can still do cell analysis, refer to cells, create charts and figures, and the like. 

In some implementations of this embodiment, end-user network-functionality 
software 1350 and runtime code in web page 1336 may cooperate with a web server extension 
1330 (FIG. 13) to periodically re-execute a query or otherwise update the dynamic data used to 

20 populate the web page. For example, a "time until stale" field may be associated with each 
query included in the spreadsheet web page. When this time expires, end-user network- 
functionality software 1350 determines whether an appropriate network coimection still exists 
for updating the dynamic data associated with the query. If the connection still exists, the query 
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is run again, and the dynamic data displayed on the web page is updated with the latest query 
results. Alternatively, web server extension 1330 may detect that data associated with a 
registered query in enhanced document web page 1370 has changed and proactively push 
updated query results to the document for viewing at the client. 
5 In some implementations of this embodiment, the developer constructing 

embedded application web pages may find that two or more pages at a given Web site (or, for 
that matter, all pages at a given site) are related and appropriate to be rendered as embedded 
apphcation web pages. In this case, a spreadsheet version of each of the two or more pages may 
be created and stored within a single enhanced spreadsheet document, on distinct spreadsheet 

10 sheets. Tbe:>c separate sheets may be linked such that navigating from one to another merely 
results in the display of a different sheet in the same enhanced spreadsheet docimient. This 
capability of storing multiple web pages within a single document provides the ability to improve 
interoperabihty and integration bet^veen what were originally disconnected pages. It also 
provides the abihty to cache, snapshot, or transmit entire web sites or portions of web sites, and 

15 work within an entire web site while disconnected from the hosting network, after having 
downloaded the single enhanced spreadsheet document containing the multiple embedded 
apphcation Web pages, and also caching snapshots of any needed population data query results. 

As the discussion relating to FIGS. 13-15 illustrates, one embodiment of the 
present invention enables the development of web pages, web applications and even web sites 

20 that can be accessed directly within non-browser client applications, such as word processors, 
spreadsheet programs, graphics applications and the like. The invention exploits both the power 
of the containing application, for content manipulation, calculation capabihties and the Hke, and 
distributed and web-based functionality typically available only through a separate web browser. 
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FIG. 16 is an illustration of a client/server architecture in accordance with another 
exemplary embodiment of the present invention, which may be used to provide a system and 
method that facilitate the cooperative writing and editing of newspaper articles and other written 
works. 

5 In this embodiment, there are three distinct users interacting with the system, with 

uses and fiinctions. The first user may be a reporter or staff writer who is responsible for 
authoring news stories for pubUcation. The writer uses a cUent computer 1602 having a word 
processing software program 1608 such as Microsoft WORD or Corel WORDPERFECT. 
Writer computer 1602 may also provided with a network-fimctionality software 1610 that 

10 enhances the functionality and communications capability of word-processing software 1608. 

The second user may be an editor on the news staff, who uses a client computer 
1632 that is provided with the word processing software 1608 and the same network- 
functionality software 1610 that the writer has on his or her client machine 1602. 

The third user may be a software developer who might be employed by, or a 

1 5 consultant to, the newspaper. The developer uses client computer 1 642 which may be provided 
with developer software comprising word processing software 1608, a developer add-in 1650, as 
well as end- user network-fimctionality software 1610. This software facilitates the creation of 
special-purpose word-processing documents that exhibit enhanced functionality and 
communications capabilities. 

20 The client/server comprises a server computer 1628. The server computer 1628 is 

preferably provided with appropriate software to support and manage various system services 
provided to the cHent computers 1602,1632,1642 through a web server 1314 with one or more 
web server extensions 1330. 
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The various client computers, and the web server 1314 are typically connected to 
a network 1 304, via respective communication links 1 306 and 1316. This network may be any 
of the various network types described previously, including for example LAN, VPN, intranet, 
extranet, or the public Internet. 
5 FIGS. 17-19 provide a detailed flow of the operation by the writers, editors and 

developers of the system, in accordance with the present invention. 

Generally, a developer at developer computer 1642 uses word processing program 
1608, including the developer add-in 1650 and the network-funciionaUty software 1610, to create 
an enhanced document-template file 1612. The enhanced document-template file includes word 

10 processing formatting defaults that satisfy the requirements for article submissions specified by 
the newspaper's editorial board and is used as a template for creation of new articles. In 
addition, the document-template file preferably includes macros and visible elements and objects 
for providing enhanced functionality to an end-user, such as a writer working at writer client ^ 
computer 1602. This enhanced document-template file maybe stored at server computer 1628 

1 5 for web-based access by staff writers. 

A writer wishing to prepare an article for publication downloads the 
document -template file to writer computer 1602 and opens the file within word processing 
software 1608. The writer is then presented with an enhanced UI, which includes one or more 
non-standard toolbars for accessing particular services from within the UI of word processing 

20 software 1 608. For example, the toolbar may include an icon for conducting database or archive 
searches via network 1304. Some or all of these services may be provided with the aid of server 
computer 1628. 
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The enhanced document-template user interface also preferably includes a 
workflow control button for changing the state of the document and notifying members of the 
editorial staff of the pending draft. Clicking on a workflow button may also cause the system to 
perform other tasks concurrently, such as time-stamping and archiving a copy of the submission. 
5 An editor, working at the editor computer 1632, may then open the submission in 

editing software 1608 and review it. The UI of editing software 1608 is also enhanced to provide 
additional functionality and workflow control capabilities through the user tools in the network- 
fimctionality software 1610. Using these workflow control capabilities, the editor may return the 
article to the writer for further revisions or forward it to another entity within the system, such as 

10 the typesetting department. 

A more detailed description of system operation as it relates to a developer is now 
provided in comiection with the flow chart of FIG. 17. In step 1702, the developer launches 
word processing software 1608, including developer add-in 1650 and the user tools which 
provide tools for inserting formatting information and runtime code into a document-template 

15 file. These tools may be made available on a developer's toolbar that is part of the software's 
UI. As a resiilt, word processing software 1608, with the developer add-in 1650 and the user 
tools piovides a powerfiil development platform for quickly and easily generating 
document-template files 1612 using simple tasks such as "drag and drop" and text insertion, as 
described in more detail below. 

20 In step 1704, the developer creates a new document-template file 1612 and inserts 

appropriate text formatting settings and content. The format defines the overall layout of the file 
as it will be displayed to the end-user (e.g., a writer) and specifies the number and type of fields 
that must be filled in before a writer may submit an article (e.g., byline, editor name, deadline 
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and the like). As noted above, formatting requirements for article submissions will typically be 
specified in advance by the newspaper's editorial board, and, as a result, the designer will often 
have little discretion in defining these features. Thus, for example, a "choose template" button 
on the developer's toolbar may pull up a menu of predefined formats that have been approved by 
5 the editorial board. The developer may then choose one, which is automatically inserted in the 
document-template file. 

In step 1706, the developer adds additional functionality to the enhanced 
document-template file 1612, For example, the developer may wish to add a workflow-control 
button to the file so that, when the button is cUcked by an end-user (such as a writer) at runtime, 
1 0 it will automatically post the file to a specified group of end-users (such as one or more editors). 

In this embodiment, adding fianctionaUty of this type to a document-template file 
may be facilitated by a tool available on the developer's toolbar. For example, the developer's 
toolbar may comprise a "workflow" button that can be dragged from the toolbar and dropped 
into the document at any desired location. A dialog box may then pop up that prompts the 
15 developer to specify details of the communication such as the identity of the editor who is to 

receive the file when the writer cHcks on the workflow button. Alternatively, some or all of this 
information may be left blank to be supplied by the writer at runtime. For example, the 
developer may add to the document-template file a pop-up menu with a complete list of editors. 
At runtime, the writer may simply choose the appropriate editor to receive draft submissions 
20 from the menu list. 

In step 1708, the developer may insert dynamic data queries into the 
document-template file. As described below, these data queries are executed at runtime by an 
end-user computer (such as writer computer 1602) to return population data that is inserted into 
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the document-template file for display to the end-user, and such queries can be made to execute 
either when the document is opened or in response to some action by an end-user such as 
chcking a button in the enhanced document. The developer's tools may preferably include a tool 
for facilitating the creation of such queries and associating them with the appropriate event in the 
5 document-template file. 

In step 1710, once the developer is satisfied with the document-template file, he 
or she saves it on server computer 1628 fi*om where it may be downloaded by a writer to client 
computer 1602, 

A more detailed description of system operation as it relates to a writer is now 
10 provided in connection with FIG. 1 8. In step 1 802, the writer launches word-processing 
software i 608 (including user tools) on the writer client computer 1 602. 

In step 1804, the writer detemiines whether he or she has previously downloaded 
an appropriate document-template file for the article to be written. If the appropriate 
docimient-template file has been previously downloaded, the writer opens the file within 
15 word-processing software 1608. Otherwise, the writer downloads the appropriate 

document-template file from, for example, server computer 1628, and opens it within 
word-processing software 1608. 

In step 1806, network-fiinctionahty soflware 1610 and/or runtime code in the 
opened document-template file 1612 cooperate to present an enhanced UI and various 
20 fimctionalities to the writer. In this exemplary embodiment, the document is enhanced in at least 
the following ways. First, it displays the document in a format that conforms to the requirements 
set by the newspaper's editorial board. Second, it executes queries in the document-template 
file, and populates fields within the document with the results of those queries. Third, it provides 
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the writer with one or more non-standard toolbar buttons or menus for accessing network-based 
services from within word-processing software 1608. These toolbars may be embedded in the 
usual toolba- section of UI of the word processor program 1608 (e.g., along the top of the UI), or 
may alternatively float at other locations within the UI. 
5 The toolbar may facilitate the end-user access to a wide variety of services. For 

example, the toolbar may include a "search" button for triggering an archival or hitemet search. 
In particular, when the writer clicks on this button, a dialog box may pop up that prompts the 
writer to enter a search term or string. Alternatively, the document may exhibit context-sensitive 
behavior, such as the user may be able to specify search terms by highhghting text within the 

1 0 open document. The dialog box may also request that the writer specify the locations to be 
searched. Thus, for example, the writer may limit the search to the newspaper's archives or 
specify that the search should include the World Wide Web. This information may be forwarded 
by writer computer 1602 to a search program on server computer 1628 or other computer. 
Search results may be returned to writer computer 1602 for display to the writer in a window 

15 within the enhanced UI of word-processor software 1608. Displayed results may be dragged 
directly from the window into the word processor document. 

In another embodiment, the UI may include a "template checker" button that will 
determine whether any specified docimaent meets the predefined formatting requirements 
specified by the newspaper's editorial board. 

20 The toolbar may also include a "review pending articles" button that allows a 

writer to v)qw a list of, for example: (1) articles currently under development, (2) favorite 
articles, (3) articles posted to the writer by other writers for review, (4) or any other personalized 
hst of articles. 
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The toolbar may also include a "live collaboration" button that launches a window 
to provide live collaboration on a document with a specified group of end-users. The 
collaboration session may be managed by appropriate software on the server computer 1628. 

In addition, the UI may include a "submit draft" button for transmitting a 
5 completed draft to an appropriate editor or editors, as described in more detail below. 

In step 1808, the writer begins the drafting process. During this process, the 
writer may, for example, type text into the document using a standard keyboard, or may copy 
text (e.g., quotes from a press release) from another document and drop the text into the 
document. In addition, the writer may employ the "search" functionality described above to 
10 identify additional archived or other material that he or she wishes to incorporate into the article.- 
Once the writer finishes the drafting process, in step 1810, the writer chcks on the 
"submit draft" button. As noted, this causes a copy of the document to be forwarded to an 
appropriate editor or editors. In addition, in some embodiments, clicking on the "submit draft" . 
button may cause other concurrent actions to be performed. For example, the system may 
15 transmit an e-mail notification to the editor or editors that a document is being sent to them for 
their review. In addition, the system may automatically timestamp and archive a copy of the 
draft submission on sender computer 1628. 

A more detailed description of system operation as it relates to an editor is now 
provided in connection with FIG. 19. As shown in Fig. 19, in step 1902, the editor receives 
20 notification that a draft has been received that requires the editor's review. In one embodiment, 
this notification may be received by e-mail. 

In step 1904, the editor launches editing software 1608 (including software 1610). 
In step 1906, the editor opens the received submission. In this exemplary embodiment, network- 
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flmctionality software 1610 and the code within the received submission may cooperate to 
provide the editor with an enhanced UI that is analogous to the enhanced user interface described 
above. It should be noted, however, that an editor will typically be provided with a plurality of 
workflow buttons due to their privileges in the workflow system, rather than the single "submit 
5 draft" button described above. More specifically, for the editor the UI dynamically provides 
both a "return to writer" button for retuming the document to the writer with revisions and 
comments, and a second button for forwarding the document to another location (e.g., the 
typesetting department) when the article is ready for publication. 

Furthermore, in some embodiments, it may be desirable to provide the editor with 
10 additional workflow buttons. For example, it may be desirable to provide an editor with a "legal 
department'' button that transmits a copy of the document to the legal department for their review 
before publication. When an editor clicks on the "legal department" button a message box may 
pop up to allow the editor to explain the reason for forwarding the article (e.g., libel concerns). 

In step 1906, the editor edits the article. During editing, the editor may revise the 
15 document and add comments or questions to it. This editing and change management handling is 
provided by the word processing software, illustrating the advantages over attempting such 
functionality out of a browser-based application. 

Once editing is completed, in step 1908, the editor determines whether the article 
is ready for pubhcation or requires additional work by the author. If the article is ready for 
20 publication, then, in step 1910, the editor clicks on an appropriate workflow button that forwards 
the article to another entity within the system, such as the typesetting department, as noted 
above. Otherwise, in step 2212, the editor chcks on a second workflow button that returns the 
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article to the writer for further drafting. This workflow process between the editor and writer 
may be repeated until the article is deemed ready for publication. 

As is made apparent in this example, this invention enables the development of an 
entirely new class of distributed applications that expose and integrate both corporate and 
5 external services and resources while running within familiar desktop applications. The resulting 
enhanced functionality can be packaged and exposed to end users as enhancements to the 
containing application itself, as elements of embedded applications embodied in enhanced 
dcjcuments, or a combination of the two. 

FIG. 20 is an illustration of a cUent/server architecture in accordance with another 
1 0 embodiment of the present invention, which may be used to provide a system and method that ^ 
allows aa illustrator or another author to create, distribute, and hcense illustrations, documents, 
and other Vvorks of authorship. 

As shown in FIG. 20, the system comprises a client computer 2002 belonging to 
an illustrator. This illustrator computer 2002 is provided with an illustrator software program 
1 5 2008 such as Adobe ILLUSTRATOR. The Illustrator computer 2002 is also preferably provided 
with a licensing add-in 2010 that enhances the functionality and communications capability of 
illustrator software program 2008. The Illustrator computer 2002 is connected to a network 
1304, such as the Internet or a private intranet, via a communications link 1306. 

The system shown in FIG. 20 further comprises a licensing web server computer 
20 2014 that is connected to network 1304 via a communications link 1316. Licensing server 2014 
is provided with a hcensing management software program 2030 that manages licensing of 
illustrations created with illustrator computer 2002, as described in more detail below. Licensing 
ser\^er 2014 is typically owned and operated by an entity in the business of managing licensed 
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works (a "licensing manager"). It should be noted that the system enables easy integration with 
existing server-based services and functionality. In this particular scenario the system could 
alternatively enable integration of an existing licensing system 2028 with the Web and 
specifically with enhanced documents through the use of licensing server 2014 and adapter web 
5 server extension code 2030. 

The system also includes a consumer interacting with a client computer 2015. For 
the purposes of this embodiment, the consumer wishes to browse and possibly purchase 
illustrations created by the illustrator. Consumer computer 2015 is connected to network 1304 
via a communications Unk 1306. Consumer computer 2015 is provided with a viewer software 
1 0 program 201 8 that facilitates viewing of illustrations 2012 that may be downloaded via network 
1304 or accessed by other means such as CD-based distribution. In addition, consumer computer 
2015 is further provided with an end-user add-in 2020, which allows the consumer to view and 
purchase licensed illustrations created with illustrator computer 2002, as described in more detail 
below. 

15 Typical operation of the present system and method will be described in detail 

below with reference to the flowcharts of FIG. 21-22. Generally, an illustrator at illustrator 
computer 2002 purchases one or more "document license controls" from the licensing manager 
that operates licensing web server 2014. Each document license control entitles the illustrator to 
certain licensing management services from licensing server 2014 for a designated illustration 
20 2012. When the illustrator designates an illustration for hcensing, the system registers the 

illustration with licensing computer 2014 and embeds licensing control code in the illustration 
document 2012 that, with the user licensing tool 2020, controls the document's subsequent use 
and distribution. 
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A consumer who downloads the illustration 2012 from, for example, the 
illustrator's Web site, may open the illustration within viewing software 2018, possibly being 
presented (by viewer add-in 2020) with a dialog box that sets forth licensing terms, restrictions, 
and other information. Alternatively, if viewing is unrestricted the consumer may not be 
5 apprised of any such licensing restrictions until attempting to execute a licensed function such as 
copying or printing the illustration. If the consumer wishes to print a copy of the illustration, the 
transaction will be confirmed with the consumer and a connection is established with licensing 
computer 2014, which electronically charges the consiuner the appropriate licensing fee. 
Printing would then commence at client computer 2015 having been allowed by end-user 

1 0 licensing add-in 2020. 

A more detailed description of system operation as it relates to an illustrator is 
now provided in connection with the flowchart of FIG. 21. As shown in FIG. 21, in step 2102, 
the illustrator launches illustrator software 2008 (including the licensing tool 2010). In step 
2104, the illustrator creates an illustration 2012 at illustrator computer 2002 using illustrator 

15 software 2008. 

In step 2106, the illustrator determines whether he or she possesses a desired 
number of "document hcense controls" from the Ucensing manager that owns licensing web 
server 2014. As noted above, each document license control entitles the illustrator to certain 
licensing management services from licensing server 2014 for a designated illustration. 
20 If the illustrator concludes that he or she has an adequate number of document 

hcense controls, flow proceeds to step 2110. Otherwise, in step 2108, the illustrator purchases a 
desired number of document license controls from the licensing manager. This transaction may. 
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for example, be conducted directly through licensing server 2014 maintained by the licensing 
manager. 

In one embodiment, the first time that the illustrator purchases a document license 
control, he or she receives a copy of hcensing tool 2010, typically downloaded to illustrator 

5 computer 2002 from licensing computer 2014 via network 2004. The licensing tool 2010 adds a 

toolbar to illustrator softw^are 2008 that includes an icon for licensing particular illustrations, as 
well as icons for displaying other licensing information, as described in more detail belov^. It 
should be noted that such special-purpose add-ins and toolbars are generally enabled by this 

system, and that a developer of such add-ins could use programming APIs and runtime support 

10 from generic add-ins and other code at either the client or server to provide easy access to 

specialized functions and services. 

Once the illustration is complete, in step 2110, the illustrator determines whether 

he or she wishes to allocate one of the purchased document license controls to this illustration 

2012, i.e., whether he or she wishes the licensing manager to manage the distnbution and 
15 licensing of this illustration. If the illustrator does not allocate a document hcensing control to 

this illustration, the flow ends at step 2112. Otherwise, flow proceeds to step 2114. 

As noted above, licensing tool 2010 displays an additional toolbar within the UI 

of illustrator software 2008. One of the icons on this toolbar is preferably a "license illustration" 

icon, which the illustrator may click on when he or she wishes to allocate a document license 
20 control to a particular illustration. Other buttons might be used, for example, to display account 

information for the illustrator with the license provider or to display specific license information 

for a viewed document that was licensed previously by the illustrator. 
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Thus, in step 2114, the illustrator (having decided to use a document license 
control for this illustration) clicks on the "hcense illustration" icon. This operation triggers 
Licensor Authentication step 2116 whereby the licensing tool 2010 displays a dialog to verify the 
illustrator's identity, hi step 21 18, a secure connection, perhaps using secure HTTP, is 
5 established between illustrator computer 2002 and licensing server 2014 via network 2004 and 

the identity of the illustrator is conveyed to the licensing server. In step 2120, licensing 

computer 20 14 transmits various pieces of information to illustrator computer 2002. For 
example, in this exemplary embodiment, hcensing server 2014 may transmit the number of 
document license controls that the illustrator has remaining. In addition, licensing server 2014 

10 may transmit updated status information concerning licensing of the illustrator's other works 

(number of licenses, dollar value of hcensing fees, etc.). As mentioned previously, additional 
icons on the toolbar may be provided to permit the illustrator to view this latter information. 

In step 2122, hcensing tool 2010 causes a dialog box to pop up that displays 
information about the document to be hcensed, such as its name, type, and size. The dialog box 

1 5 may also display additional information such as the number of remaining document license 
controls available to the illustrator (received in step 2120 above). 

Also on this hcensing dialog box, a pick list or other selection mechanism is 
provided which displays to the illustrator the available license types, fee structures, and other 
license terms. The illustrator may then specify those license terms in step 2122, as desired. In 

20 an exemplary embodiment, one menu choice may be "standard hcense," which may imphcitly 
specify a plurahty of set terms that have been predefined by the hcensing manager, the 
illustrator, or a combination of the two. Once the license terms have been specified, the 
illustrator may click on a "hcense now" button to indicate his or her approval (step 2124). 
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Clicking on the "license now" button causes a transaction to be executed with 
licensing server 2014 that consumes one of the illustrator's document license controls. In 
particular, in step 2126, a notification is transmitted from illustrator computer 2002 to licensing 
server 2014 that includes information concerning the document to be licensed. In step 2128, 

5 licensing server 2014 creates and registers a document key for the illustration that includes an 
identifier for the illustration and associated licensing terms. In step 2130, hcensing server 2014 
subtracts one from the number of document Ucense controls available to the illustrator. 

In step 2132, hcensing tool 2010 receives the new hcense information and 
embeds hcensing control code within the illustration document 2012, converting it into an 

10 enhanced illustration document. In an enhanced embodiment, this licensing control code may 
comprise a plurality of locked and write-protected macros that enforce the hcensing restrictions 
specified by the illustrator. Additionally, the hcensing tool 2010 may cause the illustration to be 
encrypted or otherwise protected such that the illustration cannot be accessed without hcensed 
use with an end-user Hcense tool 2020 in viewer software 2018. The document is then ready for 

15 publication. Thus, in step 2134, the illustrator publishes the illustration in one or more locations, 
such as on his or her web site. 

A more detailed description of system operation as it relates to a consumer is now 
provided in connection with the flowchart of FIG. 22. In step 2202, the consumer launches 
viewer software 2018 on consumer computer 2015. In step 2204, the consumer directs a browser 

20 to the illustrator's web site. In step 2206, the consumer finds an illustration of interest and 
downloads a copy of it (including the embedded licensing control information) to consumer 
computer 2015 via network 2004. In step 2208, the consumer views the downloaded illustration 
with viewer software 2018. Alternatively, the end-user could navigate to the publishing web site 
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using a browser and open the illustration directly, causing viewer software 2018 to be opened 
automatically at the client (with add-in 2020), possibly within the same containing window as 

tk browser itself. 

In step 2210, add-in 2020 and the licensing control code within the enhanced 

5 illusti-aiion document 2012 cooperate to display a dialog box indicating that the illustration is 
licensed through the hcense manager. In this embodiment, this dialog box may further comprise 
a license term button that the consumer may chck to see the license terms associated with this 
illustration, hi this embodiment, license terms for the illustration may be structured so that the 
consumer may download and view the illustration at no cost. 

10 In step 2212, the consumer examines illustration 2012 and determines whether he 

or she wishes to print a copy. If not, the flow ends at step 2214. Otherwise, the flow proceeds to 
step 2216, where end-user licensing tool 2020 causes a print dialog to be displayed that permits 
the consumer 1o set printing details. In some embodiments, this dialog may also remind the user 
of any hcensing fees. Once the consumer is satisfied with the printing details, he or she may 

1 5 click a "Prinf button (step 221 8). 

In step 2220, add-in 2020 authenticates the consumer and then establishes a 
secure HTTP session with licensing Web server 2014, as specified within the hcensing code 
embedded in the enhanced illustration itself hi step 2222, an electronic transaction is conducted 
between consumer computer 2015 and hcensing server 2014 in which the consumer is charged 

20 the licensing fee for the illustration. This charge may involve collecting charging information 
via a secure web interface or could execute automatically using known charging information for 
a frequent consumer. Then, in step 2224, the document is printed for the consumer. 
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According to the present invention, the illustrator or hcensor is able to restrict 
content that the consumer can access. For example, when the licensor is Ucensing content, he or 
she it can license the content incrementally. For example, the consumer may be allowed to view 
a synopsis section of the PC document 1 10, but not the entire PC document 1 10 until payment is 
made by the consumer. As another example, a consumer may be allowed to view a thumbnail of 
an im^age, but not the whole image until a certain date has passed. The mechanism for allowing 
such a licensing involves providing the content 615 as partially packed and partially unpacked. 
As a resuh, when it is desired that the user not be able to access certain network-based 
functionality, the content 615 will not get completely unpacked at runtime. 

In addition, it is also possible to provide application control using the licensing 
technology described above. As a result, the PC A 100 can be limited or controlled according to 
licensing rales employed. For example, a consumer may be able to see a full image but the . 
printing capabilities of the PCA 1 00 maybe disabled, so the consumer cannot print the image. 
As another example, the consumer maybe allowed to view a PC docxunent 110 but not be 
allowed to collaborate on the PC document 110 until payment is received. An exemplary 
mechanism to allow such licensing is to not allow the unpacking of a part of the network- 
enabling code 630, which deprives the consumer of the underlying functionality. 

As is made apparent by this example, the invention provides for integration of 
new functionality into existing desktop appHcations such that end-users, as opposed to 
developers, can easily create and interact with enhanced documents that leverage a variety of 
distributed services (such as the exemplary distributed licensing service), and that it provides the 
means for existing service providers to broaden their availability, utility, and overall value 
through greatly expanded access and availability. 
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The described architecture for the method and system of the present invention 
provide a wide array of both client- and server-side benefits. It enhances the functionahty 
available to an end-user by facilitating connection to network-based services (e.g., Web 

browsing, conferencing, chat, e-mail, licensing, DRM, and workflow), and making these services 

5 available within familiar and powerful PCAs. Additionally, because the enhanced PCA is 
"network aware," it can provide the end-user with distinct on-Hne and off-line usage models. 
For example, the augmented desktop application may, during on-line usage, provide access to 
network services and, during off-line usage, allow the end-user to work on previously 
downloaded content. In addition, data entered by the end-user during off-line usage may be 

10 stored for later upload and sizbsequent processing by a server (i.e., synchionization). 

Furthermore, the PCA with the network-based functionality enhances the UI 
provided to both developers and users. This enhanced UI may include non-standard toolbars and 
buttons for launching special-purpose tools and executing commands as described above. 

In addition, because the enhanced apphcation can connect to one or more remote 

15 servers, the system may efficiently allocate tasks between client and server. For example, a 
server may be tasked with collecting, processing, and formatting data required by an enhanced 
application. Enhanced pipes may be established between server and client to facilitate 
downloading of this information. Both chents and servers may also intelUgently pre- fetch 
content and data in order to respond to anticipated requests by an end-user. The ability to 

20 replicate a Web site within a PC document, and install such a PCA-based site on a client 

machine, can improve performance because only real-time dynamic data (i.e., population data) 
must be obtained over the Internet from the server. Because the present system provides for the 
separation if desired of wireframe and population data, the wireframe may be treated as a 
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versioned and infrequently downloaded independent element. This decreases bandwidth 
requirements with use and improves the end-user experience by decreasing screen-refresh times. 
It also enables more efficient caching of multiple instances at the client because the wireframe is 
cached only once. Custom, licensed, or public-domain differencing techniques may be 

5 employed to exploit this aspect of the present invention. In addition, this separation may be 
extended to multiple population data blocks per page, each of which can be managed and 
updated independently. 

Furthermore, the present system facilitates optimal workload balancing between 
cUent and server. In many cases, it may be desirable to assign various background and agent- . 

10 type tasks to the server. For example, the server may be programmed to monitor a Web site for 
changes, and notify the client when a change is detected. Document control (e.g., managing who 
has permission to modify a document), workflow processes, and PCA-based conferencing may 
also be centrally managed by a server. The server may be programmed to detect obsolete 
versions of mntime code or wireframes on the chent and update that code, either automatically or 

1 5 under the end-user's exphcit control. 

The above architecture faciUtates both unstructured use as well as more stnictured 
use. Structured use denotes the concept of a packaged appHcation. If one restricts a user's 
operations, the PCA has transformed into a new more speciaHzed application, which leverages 
the desired functionality of the original PCA. The invention can also be used in unstructured 

20 formats, typically in the form of user tools. The user tools will provide quick utilities to enhance 
the power of the PCA, such as a screen scraper. Thus, the invention is useful in the format of a 
highly structured appHcation, quick imstructured utilities, and everything in between. 
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End-users are also preferably provided with access to, and some control over, 
runtime utilities via the above architecture. For example, end-users may initiate conferences and 
chat sessions with each other from within their augmented desktop-application environments. 

Furthermore, since numerous modifications and variations will readily occur to 
those skilled in the art, it is not desired that the present invention be limited to the exact 
construction and operation illustrated. Accordingly, all suitable modifications and equivalents 
which may be resorted to are intended to fall within the scope of the claims. 
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What is claimed is: 



1 . A personal computer document with network-based functionality for use 
with a network-enabled personal computer application, comprising: 
5 a. a personal computer document capable of running on a standard 

personal computer application resident in computer memory; and 

b. network-enabling objects coupled to said personal computer 
document, wherein said network-enabling objects are configured to provide network-based 
functionality to said personal computer document, wherein said network-enabling objects are not 
1 0 inteipretable by the standard personal computer apphcation, said network-enabling objects being- 
supported by network- functionality soflware. 



?. The personal computer document claim 1, further comprising linking code 
that enables said network-enabling objects to link to network-fiinctionality code resident in the 
15 computer memory, wherein said network-functionality code enables said network-enabhng 
objects to deliver network-based functionahty within said personal computer document. 

3. The personal computer document claim 2, wherein said network-enabling 
objects are embedded in said personal computer document. 

4. The personal computer document claim 1 , further comprising linking code 
20 in communication with said network-fiinctionality code resident in the computer memory, 

wherein said linking code allows network-functionality code to function in combination with 
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said network-enabling objects to deliver network-based functionality within said personal 
computer document. 

5. A personal computer document with network-based functionality that may 
be used with an network-enabled personal computer application, comprising: 
5 a. a wireframe, wherein the wireframe comprises data and scnptmg 

code that remains static during run time of the personal computer application; and 

b. native script code in communication with said wireframe. 



6. A personal computer document with network-based functionahty that may 
1 0 be used with an network-enabled personal computer application, comprising: 

a. a wireframe, wherein the wireframe includes data and scripting 
code that remains static during run time of the personal computer application, said wireframe 
comprising: 

i, static data, and 
15 ii. query configurations; and 

b. native script code in commimication with said wireframe, said 
native script code providing network-based functionality to said personal computer document. 



7. A method of creating a personal computer document with network-based 
20 functionality using an network-enabled personal computer application, comprising: 

a. launching the network-enabled personal computer application; 

b. opening a personal computer document; 
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c. instructing said network-enabled personal computer application to 
embed network-enabling objects for implementing network-based functionality into said 
personal computer document, wherein said embedded network-enabling objects are linked to a 
network-functionality software such that use of the embedded network-enabling objects are 

5 supported by the network- functionaUty software ; and 

d. saving said personal computer document with embedded network- 
enabling objects therein. 



8. The method of claim 7, wherein said launching the network-enabled 
10 personal computer application comprises: 

a. launching a personal computer application; and 

b. launching an network-functionality software, wherein said 
network-functionality software provides network-based functionality from said personal 
computer application, wherein said personal computer application does not have said network- 

15 based functionality as standard features. 



9. A method of creating a personal computer document with network-based 
functionality using an network-enabled personal computer application, comprising: 

a. launching the network-enabled personal computer application; 
20 b, opening a personal computer document; 

c. instructing said network-enabled personal computer apphcation to 
embed network-enabling objects for implementing network-based functionality into said 
personal computer document; and 
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d. saving said personal computer document with embedded network- 
enabling objects therein. 

1 0. The method of claim 9, wherein said instructing of said network-enabled 
5 personal computer apphcation to embed network-enabling objects for implementing network- 
based fimctionality comprises encrypting code for providing network-based functionality from 
said network-enabling objects. 

1 1 . The method of claim 1 0, wherein said instructing said network-enabled 
personal computer application to embed network-enabling objects for implementing network- 

1 0 based functionalit)^ further comprises placing said code for providing network-based 

functionality from said network-enabling objects into a hidden area of the personal computer 
document after encrypting said code. 

12. A method of using a personal computer docimient with network-based 
functionality using an network-enabled personal computer application, comprising: 

1 5 a. launching the network-enabled personal computer application; and 

b. opening a personal computer document, said personal computer 
document having code for providing network-based functionahty from said network-enabhng 
objects in a hidden area, wherein said network-enabling objects provide network-based 
functionality to said personal computer documents. 



20 



13. The method of claim 12, further comprising making changes to contents of 
said personal computer document after said opening. 
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14. A method of using a personal computer document with network-based 

functionality using a network-enabled personal computer application, COmpriSlllgl 

a. launching the network-enabled personal computer application; 

5 b. opening a personal computer document from within said personal 

computer application; and 

c. activating embedded network-enabling objects for launching 
network-based functionality from within said personal computer document wherein said 
embedded network-enabling objects being capable of providing a continuous feed of network- 
1 0 based functJ onaUty to said personal computer document. 

A method of generating a personal computer document with network- 
based flmctionahty embedded therein, said personal computer document using a net-work- 
enabled personal computer apphcation, comprising: 
15 a. launching the network-enabled personal computer application upon 

request from a user; 

b. opening a personal computer document upon request from a user; 
c, embedding network-enabling objects to implement 

network-based fimctionality into said personal computer document upon request from a user; and 
20 d. saving said personal computer document with embedded network- 

enabling objects therein. 

16. The method of claim 15, wherein said embedding comprising: 
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a. reading network-functionality code from a native script code 
storage area in said personal computer document, 

b, encrypting network-functionality code for said network-enabling 

objects, and 

5 c. placing said encrypted code into a hidden area of personal 

computer document to create packed encrypted code, 

17. A method for generating a personal computer document with network- 
based functionality with the use of a network-enabled personal computer application, 

10 comprising: 

a, launching the network-enabled personal computer apphcation upon 

request from a user; 

b. opening a personal computer document upon request from said 

user: 

15 c. receiving instructions from said user to embed network-enabling 

objects that provide network-based functionality into said personal computer document; 

d. embedding network-enabhng objects into said personal computer 

document; and 

e. saving said personal computer document with embedded network- 
20 enabling objects therein. 

18. A method of running a network-enabled personal computer application for 
providing network-based functionaUty to a personal computer document, comprising: 
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a. launching the network-enabled personal computer application upon 

request from the user; 

b. opening a personal computer document upon request from the user, 
said personal computer document containing network-fimctionality code for network-enabling 

5 objects that provide network-based fimctionality to Said personal computer documents; and 

c. unpacking said network-ftinctionality code for network-enabling 
objects embedded in said personal computer document. 

19, The method of claim 18^ wherein said network- functionality code is in 
10 encrypted format, fiirther comprising decrypting the network-functionality code for network- 
enabling objects embedded in said personal computer document. 

20. A method of allowing use of a personal computer document with network- 
based fuBctioiiahty embedded therein in conjunction with a network-enabled personal computer 
application, comprising: 

15 a. launching the network-enabled personal computer application upon 

request from a user; 

b. opening a personal computer document from within said network- 
enabled personal computer application upon request from said user; 

c. changing the contents of said personal computer document upon 
20 instruction from said user; and 

d. saving said personal computer document. 
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2 1 . The method of claim 20, wherein said personal computer document 
containing packed network-functionality code in encrypted format for network-enabling objects 
that provide network-based functionahty to said personal computer documents. 

22. The method of claim 21 , further comprising unpacking said network- 

5 functionality code for network-enabling objects in said personal computer document after said 
opening a personal computer document. 

23. A method for loading a personal computer document with network-based 
functionality with the use of a network-enabled personal computer appUcation, comprising: 

a. launching the network-enabled personal computer apphcation upon 

1 0 request from a user; 

b. opening a personal computer document upon request from said 

user; 

c. receiving information regarding opening of personal computer 
document by installed base services in said network-enabled personal computer apphcation, 

1 5 d. checking by said base services to detect network-enabling objects 

for providing network-based functionality; 

e. reading of embedded network-functionahty code within said 
personal computer document to allow said network-enabling objects to launch network-based 
functionality; and 

20 f launching network-based functionality based on instructions 

included in said embedded network-functionahty code. 
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24. A method for transmitting a personal computer document with network- 

based functionality from a central server for use with an network-enabled personal computer 

application by a remote user, comprising: 

a. establishing a coimection with the remote user by a server, wherein 
5 said central server has the personal computer document with network-based functionality stored 

therein; 

b. receiving a request for said personal computer document with 
network-based functionality; and 

c. serving said personal computer document with network-based 

10 functionality. 

25. The method of claim 24, further comprising authenticating the remote user 
after said establishing said connection with the remote user. 

15 ^ 26. The method of claim 25, wherein said authenticating comprises: 

a. receiving identification information from said remote user; and 

b. determining the login status of said remote user. 

27. A method for transmitting a personal computer document with network- 
20 based functionality for use with a network-enabled personal computer application by a remote 
user, comprising: 

a. connecting the remote user to a central server, wherein said central 
server has the personal computer document with network-based functionality stored therein; 
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b. authenticating the remote user; 

c. estabUshing a secure connection with said remote user; 

d. receiving a request to download said personal computer document 
with network-based functionality from said remote user; and 

5 e. transmitting the personal computer document with network-based 

flanctionality to the remote user. 

28. A method for transmitting a personal computer document with network- 
based fimctionality for use with a network-enabled personal computer apphcation by a remote 

10 client^ comprising: 

a. receiving a login request from said client; 

b. receiving a request from said remote client at a web server for 
do\^iiloadmg said personal computer document with network-based functionahty; 

c. transmitting said request for said personal computer document 
1 5 from said web server to a web server extender; 

d. processing by said web server extender of custom request 

handling; 

e. receiving authentication information from said remote client by 
said web server extender; and 

20 f serving requested personal computer document with network- 

based frinctionality to said remote client. 
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29. The method of claim 28, wherein said custom request handUng is 
authenticating the remote client. 

30. The method of claim 28, wherein said custom request handling is deciding 
5 the version of the personal computer document to be served to said remote client. 



31. A personal computer document having network-based functionahty that 
may be used with a network-enabled personal computer apphcation, comprising: 

a. means for displaying a user-readable representation of data capable 
1 0 of ninning on a standard personal computer appHcation resident in computer memory; and 

b. means for providing network-based functionality to said personal 
computer document, said means for providing network-based functionahty coupled to said 
means for displaying a user-readable representation of data. 



15 32 . The personal computer document of claim 3 1 , further comprising means 

for linking said means for providing network-based functionality to means for displaying a user- 
readable representation of data, wherein said linking means enables said means for providing 
network-based functionality to dehver network-based functionahty within a personal computer 
document. 



20 



33. A computer device comprising: 

a computer readable medium having computer readable code means 
embodied therein, said computer readable code means comprising means for displaying a user- 
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readable representation of data having means for providing network-based functionality to said 
displaying means, said computer readable code further comprising means for linking said means 
for providing network-based functionahty to said displaying means for delivering network-based 
functionality. 

5 

34. A personal computer document having network-based functionality and 

embedded network-functionality code that may be used with a personal computer application, 

comprising: 

a. a personal computer document capable of running on a standard 
10 personal computer application resident in computer memory; and 

b. network-enabling objects coupled to said personal computer 
document, wherein said network-enabling objects are configured to provide network-based 
fimctionality to said personal computer document, wherein said network-enabling objects are not 
inlerpretable by the standard personal computer apphcation. 

15 

35. The personal computer document of claim 34, further comprising linking 
code that enables said network-enabling objects to link to network-functionahty software 
resident in the computer memory, wherein said network-functionality software enables said 
network-enabhng objects to deliver network-based functionality within said personal computer 

20 document. 

36. The personal computer document of claim 35, wherein said network- 
enabling objects are embedded in said personal computer document. 
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37. The personal computer document claim 34, further comprising linking 
code in communication with said network- functionality software resident in the computer 
memory, wherein said Unking code allows network-functionahty software to function in 
combination with said network-enabling objects to deliver network-based fimctionality within 
said personal computer document. 

38. A personal computer document with network-based functionality that may 

be used with a personal computer application, comprising: 

a, a wireframe, wherein said wireframe includes data and scripting 
code that remains static during run time of the personal computer application, said wireframe 
CGmprisir%: 

i. a native user interface, 

ii. native content visible to a user by said native user interface, 

iii. embedded network-enabling objects to provide network- 
based fancdonaliiy from within said personal computer document, said embedded network- 
enabling objects in communication with said native user interface, and 

iv. code for providing functionahty to said embedded network- 
enabling objects, said code capable of allowing said network-enabling objects to launch the 
network-based functionality from within the personal computer document; and 

b. native script code in communication with said wireframe, said 
native script code providing functionality to native functions of said personal computer 
document. 
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39. A personal computer document having network-based functionality for 
use with a network-enabled personal computer application, comprising: 

a. a wireframe, wherein said wireframe comprises Static data and 

5 static scripting code, wherein the scripting code maintains its state during run time of the 
personal computer application; 

b . population data, wherein said population data is dynamically 

generated to populate the wireframe during run time of the personal COmputer application, 
wherein said population data compliments the scripting code of the wireframe; and 
10 c. form data, wherein said form data is specified and manipulated by 

a user during run time of a personal computer apphcation for interaction with the wireframe and 
other parts of the personal computer document. 

40. The personal computer document of claim 39, wherein said wireframe 

1 5 comprises network-enabling network-enabling objects to provide network-based functionality to 
said personal computer document. 

4 1 . The personal computer document of claim 3 8, wherein said form data is 
fransmitted to a server that provides feed for the network-based functionality. 



20 



42. A method of creating a personal computer document having network- 
based functionality and embedded network-functionality code, comprising: 

a. launching a network-enabled personal computer apphcation; 
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b. opening a personal computer document; 

c. embedding network-enabling objects that implement network- 
based functionality into said personal computer document; 

d. embedding network-functionality code in said personal computer 

5 document, wherein said network-functionality code provides functionality to said embedded 

network-enabling objects; and 

e. saving said personal computer document with said embedded 
network-enabling objects and said embedded network-functionality code therein. 

10 43. The method of claim 42, wherein launching the network-enabled personal 

computer application comprises: 

a. launching a personal computer application; and 

b. launching network- functionality software, wherein said network- 
functionality software is linked to said personal computer application such that the network- 

15 functionality software adds network-based functionality to said personal computer application. 

44. A method of creating a personal computer document having network- 
based functionality and embedded network-functionality code, comprising: 
a. launching a personal computer application; 
20 b. opening a personal computer document; 

c. embedding network-enabling objects that implement network- 
based functionahty into said personal computer document, said embedding network-enabhng 
objects comprising: 
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i. encrypting code for said network-enabling objects, and 

ii. placing said encrypted code for said network-enabling 
objects into a hidden area of personal computer document; 

d. embedding network-functionality code in said personal computer 
5 document, wherein said network-functionahty code provides functionality to said embedded 
network-enabling objects, said embedding network-functionahty code comprising: 

i. encrypting network-functionality code, and 

ii, placing a part of said encrypted network-functionality code 

into said hidden area of personal computer document; and 
1 0 e. saving said personal computer document with said embedded 

netv/ork-enabhng objects and said embedded network-functionahty code therein. 

45 . A method for generating a personal computer document having network- 
bailed functionahty and embedded network-functionality code, comprising: 
1 5 a. launching a network-enabled personal computer application upon 

request from a user; 

b. providing a personal computer document upon request fi*om a user; 

c. embedding network-enabling obj ects to implement network-based 
functionality into said personal computer document by coupling said network-enabling objects to 

20 said personal computer document; 

d. embedding network- ftinctionahty code into said personal computer 
document, wherein said network-functionality code provides functionahty to said embedded 
network-enabling objects; and 
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e. saving said personal computer document with said embedded 
network-enabling objects and said embedded network-functionality code therem. 

46. A method of generating a personal computer document with network- 
5 based functionality and a network-functionaUty code embedded therein, said personal computer 
document using a network-enabled personal computer application running therewith, 
comprising: 

a. launching the network-enabled personal computer application upon 

request from a user; 

10 b. opening a personal computer document upon request from a user; 

c. embedding network-enabling objects to implement network-based 
functionality into said personal computer document upon request from a user, said embedding 
comprising: 

i. reading code from a native script code storage area in said 
1 5 personal computer document, and 

ii. encrypting code for providing network-based frmctionahty 
in said personal computer document; 

d. embedding network- fimctionality code into said personal computer 
document, wherein said network-fixnctionality code provides functionality to said embedded 

20 network-enabling objects, said embedding of network-fixnctionality code comprising: 

i. reading code from a native script code storage area in said 
personal computer document; and 

102 

563747_6 



4887-4001US1 



e. saving said personal computer document with embedded network- 
enabling objects therein. 

47. The method of claim 46, wherein said embedding network-functionality 
code into said personal computer document further comprises encrypting said network- 
functionality code after said reading code firom said native script code storage area. 

48. The method of claim 47, wherein said embedding network-functionaUty 
code into said personal computer document further comprises placing a part of said encrypted 

network-fiiTicuonality code and said network-enabling objects into a hidden area of personal 

computer document to create packed encrypted network-functionality code after said encrypting 
said network-fimctionality code. 

49. A method of allowing use of a personal computer document with network- 
based functionality in conjunction with a personal computer application, comprising: 

a. launching the personal computer application upon request from a 

user; 

b. opening a personal computer document from within said personal 
computer application upon request from said user, said personal computer document containing 
netw^ork-functionality code and network-enabling objects that provide network-based 
tunctionality to said personal computer document; 

c. unpacking said network- functionality code in said personal 

computer document; 
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d. changing the contents of said personal computer document upon 
instruction from said user; and 

e. saving said personal computer document. 

5 50. The method of claim 49, where said unpacking of network-functionality 

code compTises activating code for unpacking to run in a PCA extender of the network- 
functionality code, 

5 1 . The method of claim 50, where said unpacking of network- functionality 
10 further coviprhcs decrypting and unpacking said encrypted network-fimctionality code and code 

for net"//or]>enab]ing objects in said personal computer document upon deployment of executor 
code in said native script engine after said activating code, 

52. A method for transmitting a personal computer document having network- 
15 based functionality and embedded network- functionality code by a remote user, comprising: 

a. connecting the remote user to a central server, wherein said central 
server has access to the personal computer document having network-based functionahty and 
embedded n etwork-functionality code; 

b. authenticating the identity of the remote user; and 

20 c. transmitting the personal computer document with network-based 

functionality to the remote user. 
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53. A method for transmitting a personal computer document with network- 
based functionality embedded therein for use with a personal computer application by a remote 
client, comprising: 

a. receiving a login request from said client; 
5 b. receiving a request from said remote client for downloading said 

personal computer document with network-based functionality; 

c. transmitting said request for said personal computer document 
from a v/eb server to a web server extender; 

d. processing by said web server extender of custom request 

10 handling; 

e. receiving authentication information from said remote client by 
said web server extender; and 

f serving requested personal computer document with network- 
based fimctionality to said remote client, said personal computer document comprising network- 
15 fixnctionality code and network-enabling objects for launching said network-based fimctionaUty 
from within said personal computer document. 

54. The method of claim 53, wherein said custom request handling is 
authenticating the remote client. 

20 

55. The method of claim 53, wherein said custom request handling is deciding 
the version of the personal computer document to be served to said remote client. 
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56. A personal computer document with network-based functionality and 
having embedded network-functionality code that may be used with a personal computer 
apphcation, comprising: 

a. means for displaying a user-readable representation of data capable 
5 of running on a standard computer appUcation resident in computer memory; and 

b. means for providing network-based functionality to said personal 
computer document, said means for providing network-based functionality coupled to said 
display means; and 

c. means for linking said means for providing network-based 

iO functionality to said display means, wherein said linking means enables said means for providing 
network-based functionality to deliver network-based functionality within said personal 
computer document. 

57. A computer device comprising: 

15 a computer readable medium having computer readable code means 

embodied therein, said computer readable code means comprising means for displaying a user- 
readable representation of data having means for providing network-based functionality to said 
display means, said computer readable code further comprising means for providing support to 
said network-based functionality means and linking said means for providing network-based 

20 functionality to said displaying means for delivering network-based functionality. 

58. A system for proving network-based functionality to a personal computer 
apphcation^ comprising: 
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a. an interface for communicating \^dth said personal computer 

application; 

b. a library comprising a plurality of user tools, said user tools 
exposed to a user through a user interface, said user tools configured to provide various network- 

5 based functionalities within a personal computer document; and 

c. a PCA extender in communication with said user tools, said PCA 

extender configured to provide: 

i, network- functionality services, and 

ii, apphcation services. 

10 

59. A system for proving network-based functionality to a personal computer 

apphcation, comprising: 

a. an interface for communicating with said personal computer 

application; 

15 b. a library comprising a plurality of developer tools, said developer 

tools exposed to a user through a user interface exposed in said personal computer apphcation, 
said developer tools configured to provide various network-based functionalities to a personal 

computer document; and 

c. a PCA extender in communication with said user tools, said PCA 

20 extender configured to provide: 

i. network-functionality services, and 

ii. application services. 
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60. The system of claim 59, wherein said developer tools allow creation of a 
personal computer document with network-enabling objects embedded therein by providing 
ready-made code for embedding the network-based functionaHty by making the appropriate 
selection of the user interface of the developer tools. 

5 

61 . A system for proving network-based functionality to a personal computer 
application, comprising: 

a. an interface for communicating with said personal computer 

apph cation; 

10 b. a library comprising a plurality of user tools, said user tools 

exposed to a user through a user interface, said user tools configured to provide various network-^ 

based functionalities within a personal com.puter document; 

c. a library comprising a plurality of developer tools, said developer 

tools exposed to a user through said user interface exposed in said personal computer 
15 application, said developer tools configured to provide various network-based fimctionalities 

within a personal computer document; and 

a PCA extender m communication with said user tools, said PCA 
extender configured to provide: 

i. network-fiinctionality services, and 
20 ii, application services. 



62. An network-enabled personal computer application for allowing users to 
create personal computer documents having network-base functionality, comprising: 
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a. native personal computer application code; 

b. native object model in communication with said native personal 
computer application code; 

c. native script engine in communication with said native personal 
5 computer application code, wherein said native script engine is capable of providing 

functionality to macros; and 

d. a network- functionality package for providing network-based 
functionality within the personal computer application. 

10 63 . A network -enabled personal computer application for allowing users to 

create personal computer documents with network-based functionality, comprising; 

a. native personal computer application code; 

b. a native object model in communication with said native personal 
computer application code; 

15 c. a native script engine in communication with said native personal 

computer application code, wherein said native script engine provides functionahty to macros; 
and 

d. an add-in package, said add-in package comprising: 

i. an interface for communicating with said personal 

20 computer application; 

ii. a hbrary comprising a plurality of user tools, said user tools 
exposed to a user through a user interface, said user tools configured to provide various network- 
based functionahties within a personal computer dociunent; 
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iii. a library comprising a plurality of developer tools, said 
developer tools exposed to the user through said user interface, said developer tools configured 

to enable the creation of a personal computer document with network-based functionalities; and 

iv. a PCA extender in communication with said user tools, said 
5 PCA extender configured to provide network-functionality services and application services. 



64. A method of augmenting a personal computer application with network- 
based fiinciionality, comprising: 

a. authoring custom network-based functionahty in a compatible 
10 platform, said functionality designed to add network-based operations to the personal computer 

application; 

b. linking said authored net\^^"ork-based functionality to said personal 
computer application for allowing users to access and launch network-enabling objects fi*om - 
within said personal computer appUcation; and 

15 c. deploying said network-based functionality, wherein said 

deploymeiit allows activation of said network-enabling objects fi*om within said personal 
computer application by said users. 



65. A method of augmenting a personal computer application, comprising: 
20 a. authoring software code for network-based functionality in a 

platforai configured for use with a suitable operating system, said code for network-based 
functionality adding capability for network-based functionality to an existing personal computer 
application; 
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b. linking said software code for network-based functionality to said 
personal computer application for allowing users to launch and access network-based 

functionality from within said personal computer application; and 

c. deploying said code for network-based functionality by packaging 
5 into appropriate segments of client architecture, wherein said deployment enables use of said 

network-based functionality from within said personal computer application. 

66. The method of claim 65, further comprising obtaining a network- 
functionality software before said authoring, wherein said network-functionality software 

10 facilitates said authoring of code for network -based fanctionality within the personal computer 
application, 

67. The method of claim 66, wherein said network-functionality software 
includes a developer tool set for enabling development of an Internet-application within the 

15 personal computer application by providing the requisite means for providing creating code 
necessary for network- enabling objects, said network-enabhng objects being placed in the 
Internet-application. 

68. The method of claim 67, wherein the Internet-application is a personal 
20 computer document with network-enabling objects embedded therein. 

69. A method of augmenting a personal computer application, comprising: 
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a. launching a compatible platform to allow authoring by a user of 
custom network-based functionality, said network-based functionality designed to add network- 
based operations to the personal computer application; 

b. linking network-enabling objects to said personal computer 

5 application for allowing users to access and launch network-based functionaUty from within said 
personal computer application, said linking taking place upon instruction from said user; and 

c. deploying said network-based functionality upon instruction from 
said user, wherein said deployment allows activation of said network-enabling objects from 
within said personal computer appKcation by said users. 

10 

70. A method for transmitting a software package to augment a personal 
computer application with network-based functionality, comprising: 

a. connecting a remote user to a central server, wherein said central 
server har» access to the software package for augmenting the personal computer apphcation; and 
1 5 b. transmitting the software package to said remote user. 

71 . The method of claim 70, further comprising authenticating the identity of 
said remote user after said connecting said remote user to the central server. 

20 72. A method for transmitting a software package to augment a personal 

computer application with network-based functionality, comprising: 

a. receiving a login request from a remote client; 
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b. receiving a request from said remote client to download said 
software package from a web server; 

c, providing security authentication services to verify and 

authenticate said remote client by said web server; 

5 d. receiving authentication information from said remote client by 

web server; and 

e. serving requested software package to said remote client, said 
software package comprising network- functionality software for augmenting a personal 
computer application for launching network-based fimctionality from therein and embedding 
10 networ^c-enabling objects for network-based functionality in personal computer document.- ■ 

73. A method of augmenting a personal computer application with a plurality 
of network-based services, comprising: 

a. obtaining network-functionahty software, said network- 

1 5 functionality software including a library of routines to provide network-based functionality 
within a personal computer document opened in the personal computer application; and 

b. installing base services from said install package in said obtained 
network-functionality software. 

20 74. A method of augmenting a personal computer application with a plurality 

of network-based user tools, comprising: 
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a. obtaining a user tools software package, said user tools software 
package containing a library of files enabling use of network-based fiinctionality within a 
personal computer document opened in the personal computer application; and 

b. installing said user tools on a local client from said user tools 

5 software package. 

75. A method for creating a network-enabling object to provide network- 
based functionality to a personal computer document, comprising: 

a. receiving an information model, wherein said information model 
10 provides information for conforming the created object therewith; 

b. developing the network-enabling object to provide network-based 

ftmctionality; 

c. conforming said network-enabling object with said information 

model; 

15 d. placing said network-enabling object in an appropriate location of 

a system architecture for use in providing network-based ftmctionality to a personal computer 
document. 

76. A method for creating a network-enabhng object to provide network- 
20 based functionality, comprising: 

a) creating a new COM control; 

b) importing a requisite service library; 
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c) authoring custom functionality as a component, wherein said 
functionality is configured to enable access to network-based functionality; and 

d) registering said component as a COM component of the requisite 

service library. 

5 

77. A method for creating a network-enabling object to provide network- 
based functionality, comprising: 

a. creating a new COM control; 

b. importing a requisite service library; 

10 c. receiving an information model, wherein said information model 

provides information for conforming the created network-enabling object therewith: 

d. authoring custom functionality as a component, wherein said 
functionahty is configured to enable access to network-based functionahty; 

e. registering said component as a COM component of the requisite 

15 service library; and 

f placing said network-enabling object in an appropriate location of 

a system architecture. 

78. A method for creating a network-enabling object to provide network- 
20 based functionality, comprising: 

a. creating a new COM component for a new custom type; 

b. registering said COM component of a requisite service provider 

with said custom type; 
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c. authoring new network-based functionality; 

d. importing necessary service libraries from said requisite service 

provider; and 

e. authoring new functionality to work in conjunction with new 

5 functionaiity created during authoring of said new network-based fimctionaiity. 

79. A method for creating a network-enabling object to provide network- 
based fanctionality, comprising: 

a) selecting the requisite network-enabling object from a library of 

i 0 nctwork-eaabling obj ects; 

b) downloading a selected network-enabling object onto a personal 

computer; ■ ^ 

c) instaUing the downloaded network-enabling object; 

d) launching a network-enabled personal computer application; and 
] 5 e) adjusting settings for the installed network-enabling obj ect. 

80. The method of claim 79, wherein said library comprises a plurahty of files 
accessible from at least one of a web site, FTP site and CD-ROM. 

20 81. The method of claim 79, further comprising opening a personal computer 

document after said launching the network-enabled personal computer apphcation. 
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82 . The method of claim 8 1 , wherein the network-enabUng obj ect is 
embedded in said personal computer document after said opening of the personal computer 
application. 

83 . The method of claim 79, wherein the network-enabUng object is 
embedded within said personal computer appUcation to augment said personal computer 
application diiring said instaUing. 

84. The method of claim 79, wherein the network-enabling object is placed on 
said personal computer as a distinct icon for launching said network-based functionality from 
any software on the system during said installing. 

A method for creating a network-enabling object to provide network- 
based functionality to a personal computer document, comprising: 

a) selecting the network-enabling object from a library of network- 
enabling objects, wherein said library comprises a plurality of files accessible from at least one 
of a v/eb site, FTP site and CD-ROM; 

b) downloading the selected network-enabling object onto a personal 

computer; 

c) installing the downloaded network-enabling object on said 

personal computer; 

d) launching a network-enabled personal computer application; 

e) opening a personal computer document; 
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f) embedding said network-enabling object in said personal computer 

document; and 

g) adjusting properties of the network-enabling object. 

5 86. A method for downloading network-enabUng network-enabling objects to 

a personal computer, comprising: 

a. connecting said client to a server, said server having a library of 
network-enabjing objects stored therein; 

b. exposing the library of network-enabling objects to said client; 
1 0 c. receiving request from said cUent for downloading a network- 
enabling object from said library of network-enabling objects; and 

d. transmitting the network-enabling object to said chent. 



87. The method of claim 86, further comprising authenticating said remote 
1 5 client after said receiving of login request from the remote client. 



88. A method for downloading network-enabling objects to a personal 
computer, comprising: 

a. receiving a login request from a remote client; 
20 b. exposing a library of network-enabUng objects to said client; 

c. receiving request from said client for downloading network- 
enabhng objects from said library of network-enabhng objects; 

d. transmitting said request to a web server extender; 
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e. providing security authentication services to verify and 
authenticate said remote client by said web server extender; and 

f. transmitting the requested network-enabling object to said client. 

89. A method for downloading network-enabhng obj ects to a personal 
computer, comprising: 

a. receiving a login request jfrom the remote client; 

b. authenticating said remote client; 

c. establishing a secure connection with said client; and 

d. transmitting the requested network-enab ling object to said chent. 

90. A method for downloading aetwork-enabling obj ects to a personal 
computer, comprising: 

a. providing a secure connection to said client; 

b. exposing a library of network-enabling objects to said client; 

c. receiving request from said client for downloading a network- 
enabhng object from said library of network-enabling objects; and 

d. transmitting the network-enabhng object to said chent. 

91. A method for downloading network-enabling obj ects to a personal 
computer, comprising: 

a. providing a secure connection to said chent; 

b. exposing a library of network-enabhng objects to said chent; 
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c. receiving request from said client for downloading a network- 
enabling object from said library of network-enabling objects; 

d. transmitting said request to a web server extender; 

e. providing security authentication services to verify and 
authenticate said remote client by said web server extender; and 

f. transmitting the requested network-enabling object to said client. 

92. A network-enabling object for providing network-based functionality on a 

personal computer, comprising: 

a. code for initializing the network-enabling obj ect; 

b. code for launching network-based functionaUty in communication 
with said code for initializing the network-enabling object; and 

c. a user interface for allowing the viewing of the network-enabling 
object in an appropriate location of a system architecture, said code for exposing the object to a 
user interface in communication with said code for launching network-based functionality. 

93. The network-enabling object of claim 92, ftirther comprising code for 
registering said component as an COM component of the requisite service library, said code for 
registering said component as an COM component in communication with said code for 
initializing the network-enabling object. 

94. A network-enabling object for providing network-based functionahty on a 
personal computer, comprising: 
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a. initialization code for initializing and launching the network-based 
functionality from the network-enabling object; and 

b. run-time code for providing the network-based functionality in 

real-time from the network-enabling object. 

95 . The network-enabling obj ect of claim 94, wherein during run-time of said 
network-based functionality said initialization code remains dormant. 



96. A personal computer application having network-based functionalities, 

iO comprising; 

native code for the personal computer application, said native code 
provided with network-based functionality and non-network-based functionality for providmg 
non-network fimctionahties and network-base functionalities, wherein said network-based 
functionality provides network-based operations to the personal computer application, and said 
1 5 non-network-based functionality provides non-network-based functionality to the personal 
computer application. 

97. A personal computer appUcation having network-based functionahties, 

comprising: 

20 a. a user interface; 

b. code for providing network-based functionahties from within said 
personal computer apphcation, said network-based functionality exposed to users through said 
interface; 
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c. code for providing non-network functionalities from within said 
personal computer application, said non-network functionality exposed to users through said 
interface; and 

d. native code for the personal computer apphcation, said native code 
5 embedded v/ith said network-based functionality and said non-network-based fimctionality for 

providing non-network functionalities and network-base functionalities. 

98. The personal computer application of claim 97, wherein said code for 
providing network-based functionalities fiirther comprises a base services package in 

1 0 communication with user tools, said base services package configured to provide network- 
functionality services and apphcation services. 

99. The personal computer application of claim 98, wherein said code for 
providing network-based functionaHties further comprises a library comprising a plurality of user 

1 5 tools, said user tools exposed to a user through a user interface, said user tools configured to 
provide various network-based functionalities within a personal computer document. 

1 00. The personal computer application of claim 99, wherein said code for 
providing network-based functionalities fiirther comprises a library comprising a plurality of 

20 developer tools, said developer tools exposed to a user through said user interface, said developer 
tools configured to provide various network-based functionalities within a personal computer 
application for creating the personal computer document having network-based functionality. 
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101. A personal computer application having network-based functionalities, 

comprising: 

a. native personal computer application code; 

b. a native object model in communication with said native personal 

computer application code; 

c. a native script engine in communication with said native personal 
computer application code, wherein said native script engine provides functionaUty to native 
scripts; 

d. a user interface, said user interface allowing a user to activate said 
network-based functionaUlies and said non-network functionaUties; 

e. code for providing network-based functionalities from within said 

personal computer application; and 

f. code for providing non-network functionalities from within said 

personal computer appHcation, 

1 02. The personal computer application of claim 101, wherein said network- 
based functionality is exposed to users through said user interface. 

1 03 . The personal computer application of claim 1 02, wherein said said non- 
network functionality exposed to users through said user interface. 
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104. The personal computer application of claim 1 03, wherein said code for 
providing network-based functionalities comprises a base extender, said base extender 
comprising: 

a. code for document packaging; 
, b. code for caching of personal computer documents; 

c. code for data initialization; and 

d. code for command routing. 



105. The personal computer appHcation of claim 101, wherein said code for 
10 providing network-based functionalities comprises a library of user tools, said library comprising 
of various individual functionalities of use to an end-user. 



106. The personal computer application of claim. 1 05 , wherein said user tools 
are exposed to said user through said user interface. 

15 

1 07. The personal computer application of claim 106, wherein said code for 
providing network-based functionalities comprises a library of developer tools, said library 
comprising various tools necessary to build and deploy a personal computer document with 
network-based functionality. 

20 

1 08. The personal computer application of claim 1 07, wherein said developer 
tools are exposed to said user through said user interface, said developer tools providing users 
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with the ability to embed code for network-based functionality within said personal computer 
document by making the appropriate selection on said user interface. 

109. The personal computer application of claim 108, wherein said code for 

5 providing network-based functionalities comprises a library of network-connectivity tools, said 
library comprising: 

a. code for providing XML handling; 

b. code for session management; 

c. code for security; 

1 0 d. code for event handling; 

e. code for location handling; and 

f code for query routing. 

110, A method of creating a personal computer application having network- 
1 5 based functionahties, comprising: 

authoring native code for the personal computer apphcation, said native 
code configured to provide: 

i. non-network functionalities, and 

ii. network-based functionalities, said network-based 
20 functionalities including the ability to access a network. 
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The method of claim 110, wherein said native code comprises: 
a. a native object model, and 
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b. a native script engine in communication with said native object 
model, wherein said native script engine provides functionahty to scripts. 

112. A method of creating a personal computer application having network- 
5 based fonctionalities, comprising: 

a. authoring custom network-based functionality in a compatible 
platform for providing network-based operations to the personal computer application; 

b. authoring custom non-network-based functionality in a compatible 

platform; and 

10 c. authoring native code for the personal computer application, said 

native code embedded with said network-based functionahty and said non-network-based 
functiojiality for providing non-network functionalities and network-base functionahties. 

113. A method of creating a personal computer application having network- 
1 5 based functionalities, comprising: 

authoring native code for the personal computer application, said native 
code configured to provide non-network functionality and network-based functionalities in a 
platform configured for use with a suitable operating system, said network-based functionality 
being capable of providing real-time access to dynamic from a network. 

20 

114. A method of creating a personal computer application having network- 
based functionalities, comprising: 

126 

563747_6 



PATENT 
4887-4001US1 



a. authoring custom network-based fonctionality in a platform 
configured for use with a suitable operating system for providing network-based operations to 
the personal computer application; 

b. authoring custom non-network-based functionality in a platform 
5 configured for use with said operating system; and 

c. authoring native code for the personal computer application, said 
native code embedded with said network-based functionaUty and said non-network-based 
functionality for providing non-network functionaUties and network-base functionalities from 
v/ithin said personal computer application. 

10 

115. A method of creating a personal computer application having network- 
based functionaUties, comprising: 

a. authoring code for network-based fanctionahty in a compatible 
platform for providing network-based operations to the personal computer application; 
1 5 b. authoring code for non-network-based functionality in a 

compatible platform, said code for non-network-based functionality comprising: 

i. a native object model, and 

ii. a native script engine; and 

c. authoring native code for the personal computer application, said 
20 native code embedded with said network-based functionaUty and said non-network-based 
functionality for providing non-network functionaUties and network-base functionalities. 
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116. The method of claim 115, wherein said code for network-based 
functionality comprises a library of user tools, said user tools configured to provide: 

a. page scraping; and 

b. stock quotes in real time. 



117. The method of claim 1 1 6, wherein said code for network-based 
functionality comprises a PCA extender in communication with said user tools, said base 
extender configured to provide: 

a. document packaging; 
10 b. caching; 

c. data initiaUzation; and 

d. command routing. 

118. The method of claim 1 1 7, wherein said code for network-based 

1 5 functionality comprises a library of developer tools, said developer tools configured to provide: 

a. layout utilities; 

b. forms management; 

c. query management; 

d. data modeler; and 
20 e. packaging assistant. 

119. A method of creating a personal computer appUcation having network- 
based functionalities, comprising: 
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a. receiving code in a compatible platform for custom network-based 
functionality to provide network-based operations to the personal computer application; 

b. receiving code in a compatible platform for custom non-network- 
based functionality to provide non-network-based operations to the personal computer 
application; and 

c. receiving native code for the personal computer application in a 
compatible platform, wherein said native code is embedded with said network-based 
fiinctionahty and said non-network-based functionality. 

1 20. A method of creating a personal computer apphcation having network- 
ba^^ed functionalities, comprising; 

a. receiving code in a compatible platform for custom network-based 
functionality to provide network-based operations to the personal computer apphcation; 

b. receiving code in a compatible platform for custom non-network- 
based functionahty to provide non-network-based operations to the personal computer 
application, said code for non-network-based functionality comprising: 

i, a native object model, and 

ii. a native script engine, wherein said native script engine 
provides functionality to scripts; and 

c. receiving native code for the personal computer application, said 
native code embedded with said network-based functionality and said non-network-based 
functionahty. 
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121. A system for providing a combination of network-based services and non- 
network based services within a personal computer application, comprising: 

(a) a first component that is interpretable by a standard personal 

computer application; 

(b) a second component that is capable of providing real-time access 
to network -based services, said second component in communication with said first component, 
said second component not being interpretable by the personal computer apphcation; and 

(c) code associated with said network-enabled personal computer 
application for interpreting said second component for allowing access to said network-based 
ser/ices ^vs^ithin the network-enabled personal computer application. 

i 22 . The system of claim 121, wherein said network-based services are 
received and transmitted over a network. 



1 23 . The system of claim 1 22, wherein said network-based services provide 
d>'namic network-based content to a personal computer document, which is opened within the 
personal computer apphcation. 

1 24. The system of claim 123, wherein said dynamic network-based content is 
accessible in real-time from within the personal computer document opened in the personal 
computer application. 



125. The system of claim 124, wherein said code comprises: 
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(a) extender routines to support base functionality of said second 
component, said extender routines being external to the personal computer application; and 

(b) developer tools, said developer tools providing the capability for 
developing personal computer documents with network-enabling objects embedded therein. 

5 

126. The system of claim 125, wherein said developer tools enable creation of 
Internet applications using said personal computer apphcation, by providing means for 
embedding network-enabling objects in a personal computer document. 

10 127. The system of claim 1 26, wherein said developer tools are accessible from 

within the personal computer application. 

128. The system of claim 126, wherein said developer tools comprises a user 
interface to expose said developer tools to a user. 

15 

129. The system of claim 128, wherein said user interface is a toolbar that 
exposes a plurahty of tool sets to the user. 

130. The system of claim 128, wherein said user interface is exposed to the user 
20 within the personal computer application, said user interface appearing in addition to a standard 

toolbar of the personal computer application. 
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1 3 L The system of claim 1 26, wherein said extender routines are provided as a 
COM component. 

1 32. The system of claim 1 26, wherein the personal computer application is a 
5 spreadsheet appUcation. 

133. The system of claim 126, wherein the personal computer application is a 
word processing application. 

10 1 34. A system for providing a combination of network-based services and non- 

network based services within a personal computer application, comprising: 

(a) a first component that is interpretable by a standard personal 

computer application; 

(b) a second component that is capable of providing access to 

15 network-based services over a network in communication with said first component, wherein 
said network-based services provide dynamic network-based content to a personal computer 
document open within the personal computer application, said second component not being 
interpretable by the personal computer application; 

(c) extender routines to support base functionality of said second 
20 component, said extender routines capable of interpreting said second component for allowing 

access to said network-based services within the network-enabled personal computer appUcation; 
and 



563747_6 



132 



PATENT 
4887-4001US1 



(d) developef tools, said developer tools providing the capability for 
developing personal computer documents with network-enabling objects embedded therein, said 
developer tools accessible within the personal computer appHcation. 

5 135. The system of claim 1 34, wherein said extender routines are external to 

the personal computer application. 

136. A system for providing a combination of network-based services and non- 
network based services within a personal computer appUcation, comprising: 

1 0 (a) a first component that is capable of providing access to network- 

based setvir-es, said network-based services being received from a network for utilization within 
the personal computer apphcation, said first component providing real-time content from the 
network; and 

(b) a second component for providing non-network-based services 
15 within said personal computer application, said second component coupled to said first 
component 

137. The system of claim 136, wherein said second component is capable of 
providing static content along with the network-based services provided by said first component. 

20 

138. The system of claim 137, wherein said network-based services provide 
dynamic network-based content to a personal computer document, which is opened within the 
personal computer application. 
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139. The system of claim 138, wherein said dynamic network-based content is 
updated in real-time within the personal computer document opened in the personal computer 
application, along with static data therein. 

5 

140. The system of claim 139, wherein said first component comprises 
developer tools, said developer tools providing the capability for developing personal computer 

documents with network-enabling objects embedded therein. 

10 141 . The system of claim 140, wherein said developer tools enable creation of 

Mernet applications using said personal computer application, by providing means for • 
embedding nctwork-enabhng objects in a personal computer document. 

142. The system of claim 141, wherein said developer tools comprises a user 
1 5 interface to expose said developer tools to a user. 

143. The system of claim 142, wherein said user interface is a toolbar that 
exposes a plurality of tool sets to the user within the personal computer appUcation. 

20 144. A system for providing a combination of network-based services and non- 

network based services within a network-enabled personal computer application, comprising: 
(a) means for providing non-network based functionality; 
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(b) means for providing real-time access to network-based services, 
said means for providing real-time access to network-based services in communication with said 
means for providing non-network based functionality; and 

(c) means for interpreting means for providing real-time access to 
5 network-based services, said means for interpreting associated with said network-enabled 

personal computer appUcation for allowing access to said network-based services within the 
network-enabled personal computer appHcation. 

145. A system for providing a combination of network-based services and non- 
1 0 network based services within a personal computer appHcation, comprising: 

(a) a means for providing non-network based functionality that is 
interpreiable by a standard personal computer appUcation; 

(b) a means for providing access to network-based services over a 
network in communication with said means for providing non-network based functionality, said 

1 5 means for providing access to network-based services not being interpretable by the personal 
computer application; 

(c) means to support base functionaUty of said means for providing 
access to network-based services, wherein said means to support base functionality is capable of 
interpreting said means for providing access to network-based services; and 

20 (d) means for providing the capability to developing personal 

computer documents with network-enabUng objects embedded therein, said means for providing 
the capability to developing personal computer documents accessible from within the personal 
computer application. 
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146. A system for providing a combination of network-based services and non- 
network based services within a personal computer application, comprising: 

(a) a means for providing access to network-based services over a 
network for utilization within the personal computer application, said means for providing access 
to network-based services providing real-time content from the network; and 

(b) a means for providing non-network-based services within said personal 
computer apphcation, said second component coupled to said first component. 

147. A method for providing netw^ork-based functionality to a personal 
computer document embedded with network-enabling objects, comprising: 

a. receiving a request from the remote client to receive network- 
.based fonctionality, said remote client having requisite network-enabling softwwe stored locally; 
and 

b. providing said client with desired network-based functionality. 

148. The method of claim 147, further comprising authenticating said remote 
client after said receiving request from the remote client. 

149. The method of claim 148, further comprising providing a secure 
connection to said client by the server after said authenticating said remote chent. 
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150. A method for providing network-based functionality to a personal 
computer document embedded with network-enabling objects, said personal computer document 
open in a personal computer application, comprising: 

a. receiving a request from the remote cHent to receive network- 
based functionality, said remote client having requisite network-enabling software stored locally; 

b. authenticating said remote client; 

c. providing a secure connection to said client; and 

d. transmitting said network-based functionality through said 
network-enabling software to said remote client. 

151. The method of claim 150, wherein said network-enabling so ftware is 
being executed on said remote client along with said personal computer application. 



1 52. A method for providing network-based functionality to a personal 
1 5 computer document embedded with network-enabling objects, said personal computer document 
being executed on a remote client, the remote client connecting to a server providing support for 
the network-based functionahty, comprising: 

a. receiving a login request from the remote client; 

b. receiving a request for network-enhanced functionahty from said 

20 remote client: 

c. transmitting said request to a web server extender; 

d. providing security authentication services to verify and 
authenticate said remote client by said web server extender; and 
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e. transmitting requested network-enhanced functionality to said 

remote client. 

153. A method for providing network-based functionality to a personal 
computer document embedded with network-enabling objects, comprising: 

a. receiving a login request from the remote client; 

b. authenticating said remote client; 

c. establishing a secure connection with said client; 

d. receiving information from said client to determine whether said 
remote chent has requisite network-enabling software stored locally; and 

e. providing said cHent with desired network-based functionahty 
through said network-enabling software. 

154. A method for providing network-based functionality to a personal 
computer having a network-enabling object, comprising: 

a. providing a secure connection to said chent; 

b. transmitting a query to said remote client to determine whether 
said remote client has network-enabling software stored locally; 

c. transmitting requisite network-enabhng software to said remote 

client; and 

d. providing said client with desired network-based fimctionality 
through said network-enabhng software. 
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155. A method for providing network-based functionality to a personal 
computer having a network-enabling object, comprising: 

a. providing a secure connection to said client; 

b. receiving a request for network-enhanced functionality from said 

5 remote client; 

c. transmitting said request to a web server extender; and 

d. transmitting requested network-enhanced functionality to said 

remote client. 

10 1 56. A method for receiving network-based functionality in a personal 

computer document embedded with network-enabling objects, said personal computer document 
being stored on a remote client, the remote client connecting to a server providing support for the 
network-based functionality, comprising: 

a. sending a login request to a server providing network-based 

15 functionality: 

b. providing authenticating information; 

c. establishing a secure connection to said server; 

d. sending a request for appropriate network-based functionality to 

said server; and 

20 e. receiving feed for requested network-based functionality. 

1 57. A method for receiving network-based functionahty in a personal 
computer document embedded with network-enabling objects, said personal computer document 
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being stored on a remote client, the remote client connecting to a server providing support for the 
network-based functionahty, comprising: 

a. sending a login request to a server providing network-based 



functionality; 



b. providing authenticating information; 

c. estabUshing a secure connection to said server; 

d. receiving requisite network-enabling software from said server; 

e. sending a request for appropriate network-based functionahty; and 

f. receiving feed for requested network-based functionality. 



158. A method for receiving network-based functionality to a personal 
computer document embedded with network-enabhng objects, said personal computer document 
being stored on a remote cUent, the remote chent connecting to a server providing support for the 
network -based functionahty, comprising: 
15 a. sending a login request to said server; 

b. sending a request for network-enhanced functionality to said 

server: 

c. receiving security authentication services from said server for 
verification and authentication; 

20 d. transmitting a query to said remote client to determine whether 

said remote chent has network-enabling software stored locally; and 

e. receiving requested network-enhanced functionality. 
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159. A system for providing network-based fimctionality to personal computer 
documents embedded with network-enabling objects, said personal computer documents being 
stored on a remote client, the remote client connecting to a server providing support for the 
network-based functionality, comprising: 

a. a memory unit; 

b. a processor disposed in communication with said memory unit, 
said processor configured to: 

i. receive a login request from a remote client, 

ii. authenticate said remote chent, 

iii. connect said client to said server, and 

iv. provide said cUent with desired network-based 

functionality, 

1 60. A system for providing network-based functionahty to personal computer 
documents embedded with network-enabling objects, comprising: 

a. a memory unit; 

b. a processor disposed in commimication with said memory unit, 
said processor configiored to: 

i. receive a login request from a remote client, 

ii. authenticate said remote client, 

iii. establish connection with said client, and 

iv. provide said chent with feed for desired network-based 

functionality. 
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ABSTRACT 

A system and method for providing network-based functionality to a PC 
document. On the chent side, a personal computer application is augmented with network- 
enabling software that provides users with new network-based functionality that can be accessed 
within the personal computer application. The network-enabling software of the present 
invention enables users to generate and modify PC documents by embedding network-enabling 
objects that can launch and make use of network-based functionality from within PC documents. 
The invention further includes remote server support for the network-enabling software that 
augmei:its the PC application, and as well as support for the resulting PC documents. 
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